在Linux中执行MySQL查询是后端或DevOps开发人员的必备技能。
本文总结在bash脚本或Linux命令行界面中运行MySQL查询的四种方法,以便开发人员能够更好地处理MySQL数据库。同时希望能够对所有开发人员提供一个好参考。
注意:本文中的所有命令都不包括-p选项以输入密码,因为MySQL密码已保存在my.cnf文件中
1 使用“-e”选项运行查询
如果只想运行一个简单且短小的SQL查询,可以在查询后面使用-e选项。
mysql -uroot -D yang_db -e "SELECT * FROM t_post"
如上所示,-D选项用于指定要使用的数据库,而-e选项用于执行查询。
2 导入外部SQL文件
有时,数据库管理员可能已经准备了一个包含复杂SQL操作的SQL文件。在这些情况下,仍然可以使用如下的-e选项:
mysql -uroot -D yang_db -e "source ./getPosts.sql"
Linux中的source命令用于读取和执行文件的内容。
3 使用输入重定向导入SQL文件
如果熟悉Linux中的I/O重定向技巧,还有一种方式来导入外部的.sql文件:
mysql -uroot -D yang_db <"./getPosts.sql"
通过这种方式,不需要使用-e选项。使用<操作符就足够了。
4 使用“here-document”处理多行查询
Linux中的“here-document”概念很简单,意味着文档是“就在这里”,不在外部文件中。
语法如下:
<<MARKER
...
MARKER
整个文档都在“MARKER”之内,可以使用任何字符串作为“MARKER”。
看下面的示例:
#!/bin/sh
mysql -uroot -D yang_db <<QUERY
SELECT * FROM t_post
WHERE is_del=0
AND update_time<="2077-07-07";
QUERY
如上所示,使用QUERY作为“MARKER”。内容是要执行的SQL查询。如果把相同的查询写入外部文件并通过之前的方法导入,结果将与“here-document”方法完全相同。
默认情况下,查询的结果将输出到Linux终端。但是,如果结果很大,并且希望将其保存到单独的文件中,可以再次利用I/O重定向技巧:
#!/bin/sh
mysql -uroot -D yang_db >output.txt <<QUERY
SELECT * FROM t_post
WHERE is_del=0
AND update_time<="2077-07-07";
QUERY