设为首页 收藏本站
查看: 931|回复: 0

shell 下执行mysql 命令

[复制链接]

尚未签到

发表于 2015-4-28 10:16:46 | 显示全部楼层 |阅读模式
  原文链接
  在shell开发中,很多时候我们需要操作mysql数据库(比如:查询数据、导出数据等),但是我们又无法进入mysql命令行的环境,就需要在shell环境中模拟mysql的环境,使用mysql相关命令,本文总结几种shell操作mysql的方法,供大家参考。
方案1



  • mysql -uuser -ppasswd -e"insert LogTable values(...)"  

优点:语句简单
缺点:支持的sql相对简单
方案2

准备一个sql脚本,名字为update.sql,例如:


  • CREATE TABLE `user` (  
  •   `id` varchar(36) NOT NULL COMMENT '主键',  
  •   `username` varchar(50) NOT NULL COMMENT '用户名',  
  •   `password` varchar(50) NOT NULL COMMENT '用户密码',  
  •   `createdate` date NOT NULL COMMENT '创建时间',  
  •   `age` int(11) NOT NULL COMMENT '年龄',  
  •   PRIMARY KEY  (`id`)  
  • ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='用户信息表';  
  • DROP TABLE IF EXISTS `visit_log`;  
  • CREATE TABLE `visit_log` (  
  •   `id` varchar(36) character set utf8 NOT NULL,  
  •   `type` int(11) NOT NULL,  
  •   `content` text character set utf8 NOT NULL,  
  •   `createdate` date NOT NULL,  
  •   PRIMARY KEY  (`id`)  
  • ) ENGINE=MyISAM DEFAULT CHARSET=latin1 COMMENT='访问日志';  

新建一个update_mysql.sh,内容如下:



[python] view plaincopy
http://static.blog.iyunv.com/scripts/ZeroClipboard/ZeroClipboard.swf

  • use chbdb;  
  • source update.sql  


然后执行如下命令:



[python] view plaincopy
http://static.blog.iyunv.com/scripts/ZeroClipboard/ZeroClipboard.swf

  • cat update_mysql.sh | mysql --user=root -ppassword  

优点:支持复杂的sql脚本
缺点:
1> 需要两个文件:update.sql和update_mysql.sh
2> 一旦中间出错,之后脚本就不会执行,例如:
如果第一张表已经存在,则会报出如下异常:
ERROR 1050 (42S01) at line 1 in file: 'update.sql': Table 'user' already exists
然后脚本退出,第二张表也就无法创建。方案3

    新建一个shell脚本,格式如下:




  • #!/bin/bash  
  • mysql -u* -h* -p*  一旦中间出错,之后脚本就不会执行,例如:
    如果第一张表已经存在,则会报出如下异常:
    ERROR 1050 (42S01) at line 1 in file: 'update.sql': Table 'user' already exists
    然后脚本退出,第二张表也就无法创建。方案4

    准备一个sql脚本,如update.sql,然后执行如下命令:



    [python] view plaincopy
    http://static.blog.iyunv.com/scripts/ZeroClipboard/ZeroClipboard.swf

    • mysql -uroot -ppassword < update.sql  

    优点:支持复杂的sql脚本
    缺点:
    1> 一旦中间出错,之后脚本就不会执行,例如:
    如果第一张表已经存在,则会报出如下异常:
    ERROR 1050 (42S01) at line 1 in file: 'update.sql': Table 'user' already exists
    然后脚本退出,第二张表也就无法创建。


        大家知道在mysql命令行中使用source命令,即使中间出错,后续脚本也会继续执行,但是如上几种方式,均无法解决该问题,如果大家有好的建议,请回复,谢谢。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-61470-1-1.html 上篇帖子: Shell小技巧 下篇帖子: (C#)Windows Shell 外壳编程系列5
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表