MySQL学习——在批处理模式下使用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命令的输出重定向到一个文件中,以便后续处理或分析。

    $> 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 选项。这个 -t 选项会为输出添加表格框架,使其看起来更加整齐。如果你希望在输出中回显正在执行的语句,可以使用 mysql -v(verbose模式)选项。

另外,你也可以在mysql提示符下使用脚本,通过source命令或者\.命令来执行一个包含SQL语句的文件。例如:

mysql> source filename;

mysql> \. filename
相关推荐
一 乐28 分钟前
考研论坛平台|考研论坛小程序系统|基于java和微信小程序的考研论坛平台小程序设计与实现(源码+数据库+文档)
java·数据库·学习·考研·微信·小程序·源码
一 乐29 分钟前
租拼车平台|小区租拼车管理|基于java的小区租拼车管理信息系统小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·微信·notepad++·拼车
BillDev40 分钟前
Oracle创建用户报错-ORA-65096: invalid common user or role name
数据库·oracle
szial1 小时前
深入理解SQL模糊查询中的特殊字符处理——以DB2为例
数据库·sql
jxxchallenger1 小时前
踩坑spring cloud gateway /actuator/gateway/refresh不生效
java·数据库·gateway
William_Edmund1 小时前
C++ 算法学习——1.8 悬线法
学习
朝九晚五ฺ1 小时前
【Linux探索学习】第三弹——Linux的基础指令(下)——开启新篇章的大门
linux·运维·学习
肥or胖1 小时前
【MySQL】索引
linux·数据库·mysql
Kiwi233331 小时前
产品经理-需求分析
数据库·产品经理·需求分析
IM_DALLA1 小时前
【Verilog学习日常】—牛客网刷题—Verilog企业真题—VL74
学习·fpga开发·verilog学习