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