5

当我需要询问一个 mySQL 数据库架构问题时——我尝试“写出”我的表架构——但它很长。

所以我检查了 SO - 但我找不到答案:有没有办法自动从 mySQL(或 phpmyadmin)自动生成 ASCII 样式的数据库模式?

即我想自动得到这样的东西:

+----------+---------+----------------------------+
|  user_ID | user    |   roles                    |
+----------+---------+----------------------------+
|        1 |   Smith |    1                       |
+----------+---------+----------------------------+
|        2 |   Jones |    1                       |
+----------+---------+----------------------------+

人们是怎么做到的?什么是最好的方法?

4

3 回答 3

8

我不确定 phpMyAdmin 可以做你想做的事,但你可以通过使用 mysql 提示符来得到这个。就是这样:

假设您只需要 table 的架构my_table

如果需要,打开终端并运行mysql传递用户名 (-u) 和密码 (-p)。在 Windows 上,您可能希望确保 mysql bin 目录位于路径上(如果您在 Windows 上工作,您可能还希望mysql 在 PATH 上)。

一旦你有一个 mysql 终端;

您可能想查看哪些数据库可用:

show databases;

选择要使用的数据库:

use this_database;

您可能还希望查看哪些表可用(在此数据库中):

show tables;

现在,要查看表的架构/定义,例如my_table,运行以下命令:

describe my_table;

这应该会给你一个像这样的 ASCII 漂亮打印的输出,例如:

+--------------------+--------------+------+-----+---------+----------------+
| Field              | Type         | Null | Key | Default | Extra          |
+--------------------+--------------+------+-----+---------+----------------+
| id                 | int(11)      | NO   | PRI | NULL    | auto_increment |
| name               | varchar(50)  | NO   |     | NULL    |                |
| location_id        | int(11)      | NO   | MUL | NULL    |                |
| manager_id         | int(11)      | NO   | MUL | NULL    |                |
| other              | varchar(100) | YES  |     | NULL    |                |
| creation_timestamp | datetime     | NO   |     | NULL    |                |
| is_active          | tinyint(1)   | NO   |     | NULL    |                |
+--------------------+--------------+------+-----+---------+----------------+

如果它是您想要的模式+数据,那么您可能会通过SELECT查询来解决列名以及您想要的任何行。例如这样的:

SELECT * FROM stores LIMIT 2;

将给出以下内容:

+----+------------+-------------+------------+-------+---------------------+-----------+
| id | name       | location_id | manager_id | other | creation_timestamp  | is_active |
+----+------------+-------------+------------+-------+---------------------+-----------+
|  1 | Good Store |           1 |          1 |       | 2012-06-17 19:14:15 |         1 |
|  2 | Neu Store  |           2 |          1 |       | 2012-06-29 05:14:24 |         1 |
+----+------------+-------------+------------+-------+---------------------+-----------+

注意:在上述所有示例中,mysql 肯定会为您提供我所显示的输出(除非分页或方向发生更改),但是如果您将这个输出复制并粘贴到 SO 上,您需要复制并粘贴从终端/控制台;在标准 linux/unix 终端上,您可以使用鼠标选择输出,然后使用 将其复制到剪贴板Control+Shift+C,然后将其粘贴到 SO。在Windows上,用鼠标选择后,我想你可以右键单击并选择copy,或者你需要mark从控制台窗口中选择,然后选择输出,之后它应该会自动出现在剪贴板上供你粘贴到SO .

此外,当您将输出粘贴到 SO 上的文本框中时,不要忘记 SO 将其显示为代码,您需要选择内容,然后单击{}以将其格式化为代码。或者,只需将其左缩进,每行 4 个空格。

希望这可以解决您的问题,尽管它不像automatic您希望的那样,但我相信使用类似的脚本xclipmysql命令可以接近这个,完成automatically:-)

于 2012-08-25T14:54:49.563 回答
2

您的问题实际上是指打印表数据,而不是模式。如果我理解正确,您正在考虑以漂亮的格式打印出数据,包括精美的框架和所有内容。

在这种情况下,请查看将 MySQL 结果集导出到客户端文件的方法

特别是,您可以tee在 MySQL 命令行中使用该命令,它将您在命令行上看到的所有内容复制到文件中。例如:

mysql> tee /tmp/nice_output.txt
mysql> SELECT 1 AS one, 2, 3 FROM DUAL;
+-----+---+---+
| one | 2 | 3 |
+-----+---+---+
|   1 | 2 | 3 |
+-----+---+---+

现在使用您喜欢的编辑器打开文件并找到:

mysql> SELECT 1 AS one, 2, 3 FROM DUAL;
+-----+---+---+
| one | 2 | 3 |
+-----+---+---+
|   1 | 2 | 3 |
+-----+---+---+
1 row in set (0.00 sec)

这是您刚刚键入并在命令行上获得的内容的副本。

于 2012-08-26T04:25:47.730 回答
1

在 phpMyAdmin 中,首先选择您的数据库,然后转到导出功能,并保持结构勾选,取消勾选数据,并取消勾选另存为文件。然后,单击开始。一般来说,我一次导出所有表,但您可以使用左侧的选择器选择要导出的表。

编辑:我刚刚注意到你要求一个“模式”,但你的插图是模式和数据。尽管您可以在 phpMyAdmin 中同时导出两者,但这不会像您的插图所示那样格式化。也许最好的方法是将导出为CREATE TABLEand INSERT,然后将其添加到SQLFiddle?这样做的好处是,回答您问题的人可以轻松地创建示例并进行实验。

于 2012-08-24T12:33:18.343 回答