Related Documentation Download this Manual
PDF (US Ltr) - 39.8Mb
PDF (A4) - 39.9Mb
Man Pages (TGZ) - 257.9Kb
Man Pages (Zip) - 364.9Kb
Info (Gzip) - 4.0Mb
Info (Zip) - 4.0Mb


MySQL 8.4 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再次执行。

  • 如果你有一个产生大量输出的查询,可以将输出通过 pager 而不是让它滚动到屏幕顶部:

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

    $> mysql < batch-file > mysql.out
  • 你可以将脚本分发给其他人,让他们也能运行语句。

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

在批处理模式下,输出格式不同(更加简洁),比如mysql的输出与交互使用时不同。例如,SELECT DISTINCT species FROM petmysql交互使用时的输出如下:

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

在批处理模式下,输出则是这样:

species
bird
cat
dog
hamster
snake

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

您也可以在 mysql 提示符下使用 source 命令或 \. 命令:

mysql> source filename;
mysql> \. filename

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