相关文档 下载本手册
PDF (US Ltr) - 39.9Mb
PDF (A4) - 40.0Mb
手册页 (TGZ) - 258.5Kb
手册页 (Zip) - 365.5Kb
Info (Gzip) - 4.0Mb
Info (Zip) - 4.0Mb


MySQL 8.4 参考手册  /  教程  /  使用 mysql 批处理模式

5.5 使用 mysql 批处理模式

在前面的章节中,您使用 mysql 以交互方式输入语句并查看结果。您也可以在批处理模式下运行 mysql。为此,请将要运行的语句放入一个文件中,然后告诉 mysql 从该文件读取其输入

$> mysql < batch-file

如果您在 Windows 下运行 mysql 并且文件中的某些特殊字符会导致问题,您可以执行以下操作

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

如果您需要在命令行上指定连接参数,命令可能如下所示

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

当您以这种方式使用 mysql 时,您正在创建一个脚本文件,然后执行该脚本。

如果您希望脚本即使在其中某些语句产生错误时也继续执行,则应使用 --force 命令行选项。

为什么要使用脚本?以下是几个原因

  • 如果您反复运行一个查询(例如,每天或每周一次),将其设为脚本可以避免每次执行时都重新输入。

  • 您可以通过复制和编辑脚本文件从现有的相似查询中生成新的查询。

  • 批处理模式在您开发查询时也很有用,尤其是对于多行语句或多语句序列。如果您犯了错误,您不必重新输入所有内容。只需编辑您的脚本以更正错误,然后告诉 mysql 再次执行它。

  • 如果您有一个生成大量输出的查询,您可以将输出通过分页器,而不是看着它从屏幕顶部滚动

    $> mysql < batch-file | more
  • 您可以将输出捕获到文件中,以便进一步处理

    $> mysql < batch-file > mysql.out
  • 您可以将您的脚本分发给其他人,以便他们也可以运行这些语句。

  • 某些情况不允许交互式使用,例如,当您从 cron 作业中运行一个查询时。在这种情况下,您必须使用批处理模式。

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

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

在批处理模式下,输出改为如下所示

species
bird
cat
dog
hamster
snake

如果您希望在批处理模式下获得交互式输出格式,请使用 mysql -t。要将执行的语句回显到输出,请使用 mysql -v

您也可以通过使用 source 命令或 \. 命令从 mysql 提示符执行脚本

mysql> source filename;
mysql> \. filename

有关更多信息,请参见 第 6.5.1.5 节,“从文本文件执行 SQL 语句”