3.5 以批处理模式使用 mysql

在前面的部分中,您以交互方式使用mysql来 Importing 语句并查看结果。您也可以以批处理模式运行mysql。为此,将要运行的语句放在文件中,然后告诉mysql从文件中读取其 Importing:

shell> mysql < batch-file

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

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

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

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

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

如果您希望脚本 continue 运行,即使其中的某些语句产生错误,也应使用--force命令行选项。

为什么要使用脚本?原因如下:

shell> mysql < batch-file | more
shell> mysql < batch-file > mysql.out

在批处理模式下运行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

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

首页