如何将用于执行 MySQL 语句的内置命令(g 和 G)与终止符分号 (;) 组合使用,从而获得输出且没有任何错误?


众所周知,内置命令(\G 和 \g)将命令发送到 MySQL 服务器进行执行,借助分号 (;),MySQL 可以确定语句的结束位置。它们的结果集格式也各不相同。为了将它们组合起来并获得结果而不出错,我们需要在一个语句中编写两个查询,一个查询使用 \G 或 \g,另一个查询在末尾使用分号 (;)。

示例

组合 \G 和分号 (;) −

mysql> Select * from student\G select * from ratelist;
*************************** 1. row ***************************
  Name: Gaurav
RollNo: 100
 Grade: B.tech
*************************** 2. row ***************************
  Name: Aarav
RollNo: 150
 Grade: M.SC
*************************** 3. row ***************************
  Name: Aryan
RollNo: 165
 Grade: M.tech

3 rows in set (0.00 sec)
+----+------+-------+
| Sr | Item | Price |
+----+------+-------+
| 1  | A    | 502   |
| 2  | B    | 630   |
| 3  | C    | 1005  |
| 4  | h    | 850   |
| 5  | T    | 250   |
+----+------+-------+
5 rows in set (0.00 sec)

上面的示例中,MySQL 语句首先在第一个查询后遇到 \G,并基于它以垂直格式显示结果集,然后在第二个查询后遇到分号 (;) 作为终止符,并基于它以表格格式显示结果集。

示例

组合 \g 和分号 (;) −

mysql> Select * from student\g select * from ratelist;
+--------+--------+--------+
| Name   | RollNo | Grade  |
+--------+--------+--------+
| Gaurav | 100    | B.tech |
| Aarav  | 150    | M.SC   |
| Aryan  | 165    | M.tech |
+--------+--------+--------+

3 rows in set (0.00 sec)
+----+------+-------+
| Sr | Item | Price |
+----+------+-------+
| 1  | A    | 502   |
| 2  | B    | 630   |
| 3  | C    | 1005  |
| 4  | h    | 850   |
| 5  | T    | 250   |
+----+------+-------+
5 rows in set (0.00 sec)

在上面的示例中,MySQL 语句首先在第一个查询后遇到 \g,并基于它以表格格式显示结果集,然后在第二个查询后遇到分号 (;) 作为终止符,并基于它也以表格格式显示结果集。

更新于:2020年6月22日

86 次浏览

启动您的 职业生涯

完成课程获得认证

开始学习
广告