Related Documentation Download this Manual
PDF (US Ltr) - 40.8Mb
PDF (A4) - 40.9Mb
Man Pages (TGZ) - 294.0Kb
Man Pages (Zip) - 409.0Kb
Info (Gzip) - 4.0Mb
Info (Zip) - 4.0Mb
Excerpts from this Manual

MySQL 8.3 Reference Manual  /  Tutorial  /  Using mysql in Batch Mode

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 时不同(更简洁),与交互式使用时不同。例如,SELECT DISTINCT species FROM pet 的输出结果在交互式使用时如下所示:

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

在批处理模式下,输出结果如下所示:

species
bird
cat
dog
hamster
snake

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

您也可以使用 mysql 提示符中的脚本,使用 source 命令或 \. 命令:

mysql> source filename;
mysql> \. filename

请参阅 第 6.5.1.5 节,“从文本文件执行 SQL 语句”,以获取更多信息。