2012-09-27 28 views
0

我在这里有一个愚蠢的问题。这不是什么大不了的事情,但是因为我几乎每天都有这种情况,所以我正在寻找解决方法。输出n列数据库中的所有表格

我正在处理一个有250个表格的项目。我经常需要查看这些列表,但是当我启动“显示表”时,MySQL每行输出1列。

下面是一个简单示例:

| contact        | 
| content_footer      | 
| content_footer_translation   | 
| content_homepage      | 
| content_homepage_image    | 
| content_homepage_translation   | 

我想是能够通过设N自己,甚至更好的N列来显示它,正应的方式,这样可以计算线宽不会超过X个字符。

预期输出:

| contact        | content_footer      | content_footer_translation   | 
| content_homepage      | content_homepage_image    | content_homepage_translation   | 

我不知道这是真的有可能这样做纯粹是在MySQL,但如果你知道一个很好的一个班轮它可以做,在bash中,它也没关系:)

+0

可以输出为HTML吗? – Randy

+0

不,我在命令行中使用它,目标是全面查看所有表格。使用HTML,它会变得更加丑陋:P – haltabush

回答

1

试试这个:

mysql databasename -NBe 'show tables;' | fmt 

这将名字结合起来,适当长度的线。您可以使用-w标志调整线路长度至fmt。但它不会形成新的专栏。

这确实建柱一种解决方案是以下之一:

set -- $(mysql databasename -NBe 'show tables') '' '' 
while [[ $# -ge 3 ]]; do 
    printf "| %-20s | %-20s | %-20s |\n" "$1" "$2" "$3" 
    shift 3 
done 

这是写在五行的可读性,虽然你当然可以用分号单独的逻辑行写。如果要调整列数,则必须在五个位置执行此操作:空字符串的数量,循环测试,格式字符串,printf参数和移位参数。如果要调整列宽,则必须在格式字符串中重复执行此操作。不涉及自动计算。

+0

非常好!我不接受你的答案,如果有人有任何想法将其显示为固定宽度列 – haltabush

+0

这对我的用例足够好了:)谢谢! – haltabush

相关问题