我正在使用PuTTY运行:

mysql> SELECT * FROM sometable;

Sometable有许多字段,这导致许多列试图显示在终端中。字段换行到下一行,因此很难将列标题与字段值对齐。

在终端中查看这些数据有什么解决方案?

我没有也不想访问phpMyAdmin -或任何其他GUI界面。我正在寻找这样的命令行解决方案:将MySQL查询结果保存为文本或CVS文件


当前回答

用\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
          ...

其他回答

你可以使用tee将你的查询结果写入一个文件:

tee somepath\filename.txt

我相信putty具有您可以为窗口指定的最大列数。

对于Windows,我个人使用Windows PowerShell,并将屏幕缓冲宽度设置得相当高。列宽度保持固定,您可以使用水平滚动条查看数据。我也有过和你现在一样的问题。

编辑:对于远程主机,你必须SSH进入,你会使用一些像plink + Windows PowerShell

你可能也会发现这很有用(非windows):

mysql> pager less -SFX
mysql> SELECT * FROM sometable;

这将通过less命令行工具(带有这些参数)管道输出,该工具将为您提供一个可以用光标键水平和垂直滚动的表格输出。

点击q键离开这个视图,这将退出less工具。

尝试启用垂直模式,使用\G来执行查询,而不是;:

mysql> SELECT * FROM sometable \G

结果将以垂直模式列出,因此每个列的值将打印在单独的行上。输出将更窄,但显然更长。

默认的分页器是stdout。标准输出有列限制,因此输出将被换行。您可以将其他工具设置为分页器来格式化输出。有两种方法。一是对列进行限制,二是在vim中对列进行处理。

第一种方法:

➜  ~  echo $COLUMNS
179

mysql> nopager
PAGER set to stdout
mysql> pager cut -c -179
PAGER set to 'cut -c -179'
mysql> select * from db;
+-----------+------------+------------+-------------+-------------+-------------+-------------+-------------+-----------+------------+-----------------+------------+------------+-
| Host      | Db         | User       | Select_priv | Insert_priv | Update_priv | Delete_priv | Create_priv | Drop_priv | Grant_priv | References_priv | Index_priv | Alter_priv |
+-----------+------------+------------+-------------+-------------+-------------+-------------+-------------+-----------+------------+-----------------+------------+------------+-
| %         | test       |            | Y           | Y           | Y           | Y           | Y           | Y         | N          | Y               | Y          | Y          |
| %         | test\_%    |            | Y           | Y           | Y           | Y           | Y           | Y         | N          | Y               | Y          | Y          |
| localhost | phpmyadmin | phpmyadmin | Y           | Y           | Y           | Y           | Y           | Y         | N          | Y               | Y          | Y          |
| localhost | it         | it         | Y           | Y           | Y           | Y           | Y           | Y         | N          | Y               | Y          | Y          |
+-----------+------------+------------+-------------+-------------+-------------+-------------+-------------+-----------+------------+-----------------+------------+------------+-
4 rows in set (0.00 sec)

mysql>

输出不完整。内容适合你的屏幕。

第二点:

在.vimrc中设置vim模式为nowrap

➜  ~  tail ~/.vimrc

" no-wrap for myslq cli
set nowrap

mysql> pager vim -
PAGER set to 'vim -'
mysql> select * from db;
    Vim: Reading from stdin...
+-----------+------------+------------+-------------+-------------+----------
| Host      | Db         | User       | Select_priv | Insert_priv | Update_pr
+-----------+------------+------------+-------------+-------------+----------
| %         | test       |            | Y           | Y           | Y
| %         | test\_%    |            | Y           | Y           | Y
| localhost | phpmyadmin | phpmyadmin | Y           | Y           | Y
| localhost | it         | it         | Y           | Y           | Y
+-----------+------------+------------+-------------+-------------+----------
~
~
~