我在这里遇到了一个愚蠢的问题。这不是什么大问题,但几乎每天都有,我正在寻找解决方法。
我正在处理一个项目,其中有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中做到这一点,那也很好:)
答案 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参数。如果要调整列宽,则必须在格式字符串中重复这样做。不涉及自动计算。