在前面的部分中,您以交互方式使用mysql命令输入语句并查看结果。您也可以以批处理模式运行。为此,将要运行的语句放在文件中,然后告诉 mysql从文件中读取其输入:
shell>mysql < batch-file
如果您在Windows下运行SQL文件,则可以执行以下操作:
C:\> mysql -e "source batch-file"
如果需要在命令行上指定连接参数,则命令可能如下所示:
shell>mysql -h host -u user -p < batch-file
Enter password: ********
如果其中的某些语句产生错误,您希望脚本继续运行,也应使用 --force命令行选项。
为什么要使用脚本?原因如下:
如果定时运行查询(例如每天或每周),将其设置为脚本可以避免每次执行时都重新键入查询。
在开发查询时,批处理模式也很有用,尤其是对于多行语句或多语句序列。如果输入有误,则无需重新输入所有内容。只需编辑脚本以纠正错误,然后告诉mysql重新执行即可。
如果查询产生大量输出,则可以通过分页模式运行输出,而不用看着它滚动到屏幕顶部:
shell>mysql < batch-file | more
您可以将输出捕获到文件中以进行进一步处理:
shell>mysql < batch-file > mysql.out
您可以将脚本分发给其他人,以便他们也可以运行语句。
某些情况不允许交互使用,例如,当您从cron作业运行查询时。在这种情况下,您必须使用批处理模式。
当以批处理方式运行mysql时,默认输出格式与交互式使用时不同(更为简洁) 。例如,以交互方式运行SELECT DISTINCT species FROM pet 时,输出如下 :
+---------+
| species |
+---------+
| bird |
| cat |
| dog |
| hamster |
| snake |
+---------+
在批处理模式下,输出看起来像这样:
species
bird
cat
dog
hamster
snake
如果要以批处理方式获取交互式输出格式,请使用mysql -t。要将执行的语句回显到输出,请使用mysql -v。
您也可以使用以下命令 source 来使用脚本,如下:
mysql>source filename;
mysql>\. filename