我正在使用PuTTY运行:
mysql> SELECT * FROM sometable;
Sometable有许多字段,这导致许多列试图显示在终端中。字段换行到下一行,因此很难将列标题与字段值对齐。
在终端中查看这些数据有什么解决方案?
我没有也不想访问phpMyAdmin -或任何其他GUI界面。我正在寻找这样的命令行解决方案:将MySQL查询结果保存为文本或CVS文件
我正在使用PuTTY运行:
mysql> SELECT * FROM sometable;
Sometable有许多字段,这导致许多列试图显示在终端中。字段换行到下一行,因此很难将列标题与字段值对齐。
在终端中查看这些数据有什么解决方案?
我没有也不想访问phpMyAdmin -或任何其他GUI界面。我正在寻找这样的命令行解决方案:将MySQL查询结果保存为文本或CVS文件
当前回答
使用mysql的ego命令
mysql的帮助命令:
自我(\G)发送命令到mysql服务器,结果垂直显示。
所以通过添加\G到你的选择,你可以得到一个非常干净的垂直输出:
mysql> SELECT * FROM sometable \G
使用寻呼机
你可以用-S选项让MySQL使用更少的分页器,它可以剪切宽的行,并给你一个可以用方向键滚动的输出:
mysql> pager less -S
因此,下次你运行一个输出宽的命令时,MySQL会让你用更少的分页器浏览输出:
mysql> SELECT * FROM sometable;
如果你用完了寻呼机,想回到标准输出的常规输出,使用这个:
mysql> nopager
其他回答
我相信putty具有您可以为窗口指定的最大列数。
对于Windows,我个人使用Windows PowerShell,并将屏幕缓冲宽度设置得相当高。列宽度保持固定,您可以使用水平滚动条查看数据。我也有过和你现在一样的问题。
编辑:对于远程主机,你必须SSH进入,你会使用一些像plink + Windows PowerShell
尝试启用垂直模式,使用\G来执行查询,而不是;:
mysql> SELECT * FROM sometable \G
结果将以垂直模式列出,因此每个列的值将打印在单独的行上。输出将更窄,但显然更长。
用\G代替;终止查询。例如:
SELECT * FROM sometable\G
这个查询垂直显示行,像这样:
*************************** 1. row ***************************
Host: localhost
Db: mydatabase1
User: myuser1
Select_priv: Y
Insert_priv: Y
Update_priv: Y
...
*************************** 2. row ***************************
Host: localhost
Db: mydatabase2
User: myuser2
Select_priv: Y
Insert_priv: Y
Update_priv: Y
...
我写了pspg - https://github.com/okbob/pspg
这个寻呼机是为表格数据设计的- MySQL也被支持。
MariaDB [sakila]> pager pspg -s 14 -X --force-uniborder --quit-if-one-screen PAGER set to 'pspg -s 14 -X --force-uniborder --quit-if-one-screen' MariaDB [sakila]> select now(); MariaDB [sakila]> select * from nicer_but_slower_film_list limit 100;
使用mysql的ego命令
mysql的帮助命令:
自我(\G)发送命令到mysql服务器,结果垂直显示。
所以通过添加\G到你的选择,你可以得到一个非常干净的垂直输出:
mysql> SELECT * FROM sometable \G
使用寻呼机
你可以用-S选项让MySQL使用更少的分页器,它可以剪切宽的行,并给你一个可以用方向键滚动的输出:
mysql> pager less -S
因此,下次你运行一个输出宽的命令时,MySQL会让你用更少的分页器浏览输出:
mysql> SELECT * FROM sometable;
如果你用完了寻呼机,想回到标准输出的常规输出,使用这个:
mysql> nopager