从n列的数据库中输出所有表

时间:2012-09-27 12:41:04

标签: bash mysql

我在这里遇到了一个愚蠢的问题。这不是什么大问题,但几乎每天都有,我正在寻找解决方法。

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

以下是一个快速示例:

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

我想要的是能够通过定义n我自己来显示n列,或者甚至更好,n应该以某种方式计算,以便线宽不会超过X个字符。

预期产出:

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

我不确定它是否真的可以在MySQL中完全实现,但是如果你知道一个很好的单行程可以在Bash中做到这一点,那也很好:)

1 个答案:

答案 0 :(得分: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参数和shift参数。如果要调整列宽,则必须在格式字符串中重复这样做。不涉及自动计算。