是否有可能以某种方式获取MySQL数据库的结构,或者只是一些具有简单查询的表?
还是有另一种方法,我该怎么办?
是否有可能以某种方式获取MySQL数据库的结构,或者只是一些具有简单查询的表?
还是有另一种方法,我该怎么办?
Answers:
要将整个数据库结构作为一组CREATE TABLE语句获取,请使用mysqldump:
mysqldump database_name --compact --no-data
对于单个表,在mysqldump中的表名之后添加表名。使用SQL和SHOW CREATE TABLE可以获得相同的结果:
SHOW CREATE TABLE table;
或DESCRIBE(如果您希望使用列列表):
DESCRIBE table;
show create table
正是我想要的。谢谢!
看一下INFORMATION_SCHEMA
。TABLES
表。它包含有关所有表的元数据。
例:
SELECT * FROM `INFORMATION_SCHEMA`.`TABLES`
WHERE TABLE_NAME LIKE 'table1'
与其他方法相比,此方法的优势在于您可以轻松地将上述查询作为其他查询中的子查询使用。
information_schema
。columns
(使用columns
table而不是tables
?因为tables
不包含有关表列类型的任何信息
SELECT *
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_SCHEMA = 'test' AND TABLE_NAME ='products';
Table_schema
数据库名称在哪里
SELECT TABLE_NAME, COLUMN_NAME, DATA_TYPE, IS_NULLABLE, COLUMN_COMMENT FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = 'my_db_name' AND TABLE_NAME ='users';
那就是SHOW CREATE TABLE查询。您也可以查询SCHEMA TABLES。
SHOW CREATE TABLE YourTableName;
我发现有用的第一个答案的变体
打开命令提示符并输入(您不必登录到mysql服务器)
mysqldump -hlocalhost -u<root> -p<password> <dbname> --compact --no-data > </path_to_mydump/>mysql.dmp
在以下示例中,
playground
是数据库名称和equipment
表名称
另一种方法是使用SHOW-COLUMNS:5.5(也可用于5.5>
)
$ mysql -uroot -p<password> -h<host> -P<port> -e \
"SHOW COLUMNS FROM playground.equipment"
并输出:
mysql: [Warning] Using a password on the command line interface can be insecure.
+-------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| type | varchar(50) | YES | | NULL | |
| quant | int(11) | YES | | NULL | |
| color | varchar(25) | YES | | NULL | |
+-------+-------------+------+-----+---------+----------------+
也可以使用mysqlshow-client(也可用于5.5>
),如下所示:
$ mysqlshow -uroot -p<password> -h<host> -P<port> \
playground equipment
并输出:
mysqlshow: [Warning] Using a password on the command line interface can be insecure.
Database: playground Table: equipment
+-------+-------------+-------------------+------+-----+---------+----------------+---------------------------------+---------+
| Field | Type | Collation | Null | Key | Default | Extra | Privileges | Comment |
+-------+-------------+-------------------+------+-----+---------+----------------+---------------------------------+---------+
| id | int(11) | | NO | PRI | | auto_increment | select,insert,update,references | |
| type | varchar(50) | latin1_swedish_ci | YES | | | | select,insert,update,references | |
| quant | int(11) | | YES | | | | select,insert,update,references | |
| color | varchar(25) | latin1_swedish_ci | YES | | | | select,insert,update,references | |
+-------+-------------+-------------------+------+-----+---------+----------------+---------------------------------+---------+
SELECT COLUMN_NAME
FROM INFORMATION_SCHEMA
。COLUMNS
WHERE TABLE_SCHEMA
='bodb'AND TABLE_NAME
='abc';
用于获取所有列名
SHOW TABLES FROM database_name