mysql 执行结果输出格式问题, 未显示为表格样式

2019-02-22 17:59:44 +08:00
 c4f36e5766583218

一. console

shell>mysql -Auxxx
mysql>select 1 from dual;
+---+
| 1 |
+---+
| 1 |
+---+

shell>mysql -uxxx -e "select 1 from dual;"
+---+
| 1 |
+---+
| 1 |
+---+

二. watch

shell>watch -n 30 'mysql -uxxx -e "select 1 from dual;"'
Every 30.0s: mysql -uroot -e "select 1 from dual;"
1
1

为什么 2 没有显示为表格样式?

3228 次点击
所在节点    MySQL
6 条回复
akira
2019-02-22 18:09:23 +08:00
没试过这样用,加个 -t 参数试试?
ETiV
2019-02-22 18:22:12 +08:00
mysql -e "XXX" > records.txt

输出给管道也有同样效果

就像 curl "XXX" 和 curl "XXX" > output,显示在终端里的内容可以不一样(例子举的不恰当,但是 curl 能判断出 stdout 被重定向了)

所以可能 mysql 程序在判断出 stdout 被管道了之后,就取消了表格样式的输出吧(为了更好的用 grep、sed 之类的处理)
c4f36e5766583218
2019-02-22 18:31:18 +08:00
@akira 果然厉害~3q , (看 man mysql 没看仔细。
@ETiV 我起初也猜想到是检测到 console 可以有样式调整
c4f36e5766583218
2019-02-23 22:26:02 +08:00
@akira 那如何显示汇总结果呢? 1 row in set (0.65 sec). 这种
c4f36e5766583218
2019-02-23 22:38:03 +08:00
-v : 输出执行语句
-vv: +汇总信息
-vvv: +表格样式+执行耗时
c4f36e5766583218
2019-02-23 22:40:21 +08:00
-vv: +汇总信息+Bye

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/537729

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX