如何在shell中操做mysql数据库

我知道的有以下两种方式能够在shell中访问操做mysql数据库 1. mysql -uusername -ppasswd -e "command;command" [root@localhost ~]# mysql -uroot -p123456 -e "select user,host from mysql.user" +------+-----------------------+ | user | host                  | +------+-----------------------+ | root | %                     | | root | 127.0.0.1             | | php  | localhost             | | root | localhost             | | root | localhost.localdomain | +------+-----------------------+ 请看下面这段文字:(引自mysql参考手册) 对mysql偶尔有用的另外一个选项是-e或--execute选项,可用来将SQL语句传递给服务器。该语句必须 用引号引发来(单引号或双引号)。(然而,若是想要在查询中将值引发来,则对于查询应使用双引号 ,查询中引用的值应使用单引号)。当使用该选项时,语句被执行,而后mysql当即退出命令外壳。 例如,你能够用下面的命令得到用户帐户列表: shell> mysql -u root -p -e "SELECT User, Host FROM User" mysql 请注意mysql数据库名做为一个独立的参量传递。然而,相同的查询可能已经使用mysql -u root -p -e "SELECT User,Host FROM mysql.User"从外壳中执行。 能够按这种方式传递多个SQL语句,用分号隔开: shell> mysql -u root -p --execute="SELECT Name FROM Country WHERE Name LIKE 'AU%';SELECT COUNT(*) FROM City" world 2. 若是sql语句比较多,可以使用以下方式: [root@localhost ~]# mysql -uroot -p123456 << EOF > use mysql; > select user,host from user; > EOF user    host root    % root    127.0.0.1 php     localhost root    localhost root    localhost.localdomain 从查询结果中能够看出,二者的输出结果格式不同,前一种方式保留了mysql的输出格式。 另外,与此篇文章有关的shell 重定向知识,能够查阅ABS guide第16章节“I/O重定向”和第17章节“Here Documents”
相关文章
相关标签/搜索