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

    1. $> mysql < batch-file

    如果您在 Windows 下运行 mysql 并且文件中有一些导致问题的特殊字符,您可以这样做:

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

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

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

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

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

    为什么要使用脚本?这里有几个原因:

    • 如果您重复运行查询(例如,每天或每周),将其设为脚本可以避免每次执行时都重新键入它。
    • 您可以通过复制和编辑脚本文件从现有的类似查询中生成新查询。
    • 在开发查询时,批处理模式也很有用,特别是对于多行语句或多语句序列。如果您犯了错误,您不必重新输入所有内容。只需编辑您的脚本以更正错误,然后告诉 mysql 再次执行它。
    • 如果您有一个产生大量输出的查询,您可以通过寻呼机运行输出,而不是看着它从屏幕顶部滚动:

      1. $> mysql < batch-file | more
    • 您可以在文件中捕获输出以进行进一步处理:

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

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

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

    1. +---------+
    2. | species |
    3. +---------+
    4. | bird |
    5. | cat |
    6. | dog |
    7. | hamster |
    8. | snake |
    9. +---------+

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

    1. species
    2. bird
    3. cat
    4. dog
    5. hamster
    6. snake

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

    您还可以通过使用 source 命令或 \ 来使用 mysql 提示符下的脚本。命令:

    1. mysql> source filename;
    2. mysql> \. filename