MySQL™ 参考手册(在批处理模式下使用mysql)

在批处理模式下使用mysql

在前面的部分中,你以交互方式使用mysql输入语句并查看结果,你也能够在批处理模式下运行mysql,为此,将要运行的语句放在文件中,而后告诉mysql从文件中读取其输入:mysql

shell> mysql < batch-file

若是你在Windows下运行mysql并在文件中有一些致使问题的特殊字符,你能够这样作:sql

C:\> mysql -e "source batch-file"

若是须要在命令行上指定链接参数,则命令可能以下所示:shell

shell> mysql -h host -u user -p < batch-file
Enter password: ********

当你以这种方式使用mysql时,你将建立一个脚本文件,而后执行该脚本。数据库

若是你但愿脚本继续运行,即便其中的某些语句产生错误,你应该使用--force命令行选项。segmentfault

为何要使用脚本?缘由以下:命令行

  • 若是你反复运行查询(例如,天天或每周),使其成为脚本使你能够避免每次执行它时从新输入它。
  • 你能够经过复制和编辑脚本文件从现有的查询生成新查询。
  • 在开发查询时,批处理模式也颇有用,特别是对于多行语句或多语句序列,若是你犯了一个错误,你没必要从新输入全部内容,只需编辑脚本以更正错误,而后告诉mysql再次执行它。
  • 若是你有一个产生大量输出的查询,你能够经过寻呼机运行输出,而不是看着它从屏幕顶部滚动:code

    shell> mysql < batch-file | more
  • 你能够捕获输出到文件中以进行进一步处理:ci

    shell> mysql < batch-file > mysql.out
  • 你能够将脚本分发给其余人,以便他们也能够运行语句。
  • 某些状况不容许交互式使用,例如,当你从cron做业运行查询时,在这种状况下,你必须使用批处理模式。

在批处理模式下运行mysql时,默认输出格式与交互使用时的默认输出格式不一样(更简洁)。例如,当交互式运行mysql时,SELECT DISTINCT species FROM pet的输出以下所示:开发

+---------+
| species |
+---------+
| bird    |
| cat     |
| dog     |
| hamster |
| snake   |
+---------+

在批处理模式下,输出看起来像这样:get

species
bird
cat
dog
hamster
snake

若是要以批处理模式获取交互式输出格式,请使用mysql -t,要回显输出执行的语句,请使用mysql -v

你还可使用source命令或\.命令从mysql提示符中使用脚本:

mysql> source filename;
mysql> \. filename

上一篇:获取有关数据库和表的信息

相关文章
相关标签/搜索