MySQL——檢視資料表結構
阿新 • • 發佈:2019-01-30
1. 查看錶的基本結構語句 DESCRIBE
用 DESCRIBE/DESC 語句可以查看錶的欄位資訊,其中包括欄位名、欄位資料型別、是否為主鍵、是否有預設值等。
語法規則如下:
DESCRIBE 表明;
或者簡寫為:
DESC 表明;
【例】 分別使用 DESCRIBE 和 DESC 語句查看錶 tb_dept1 和表 tb_emp1 的表結構。
檢視 tb_dept1 表的結構,SQL 語句及執行結構如下:
mysql> DESCRIBE tb_dept1; +----------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(22) | NO | | NULL | | | location | varchar(50) | YES | | NULL | | +----------+-------------+------+-----+---------+-------+
檢視 tb_emp1 表的結構,SQL 語句及執行結構如下:
mysql> DESC tb_emp1; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | YES | | NULL | | | name | varchar(25) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+
【注】:
NULL:表示該列是否可以儲存 NULL 值。
Key: 表示該列是否已編制索引。PRI 表示該列是表主鍵的一部分;NUI 表示該列是 UNIQUE 索引的一部分;MUL 表示在列中某個給定值允許出現多次。
Default: 表示該列是否有預設值,如果有,值是多少。
Extra:表示可以獲取的與給定列有關的附加資訊,例如 AUTO_INCREMENT等。
2. 查看錶的詳細結構語句 SHOW CREATE TABLE
用 SHOW CREATE TABLE 語句可以顯示建立表時的 CREATE TABLE 語句,
語法格式如下:
SHOW CREATE TABLE <表明\G>;
如果不加 "\G" 引數,顯示的結果可能比較混亂,加上之後,顯示的結果更加直接。
【例】 使用 SHOW CREATE TABLE 語句檢視 tb_emp1 的詳細資訊,結果如下:
mysql> SHOW CREATE TABLE tb_emp1;
+---------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+---------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| tb_emp1 | CREATE TABLE `tb_emp1` (
`id` int(11) DEFAULT NULL,
`name` varchar(25) DEFAULT NULL,
`deptId` int(11) DEFAULT NULL,
`salary` float DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+---------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
使用了 "\G" 引數後結果:
mysql> SHOW CREATE TABLE tb_emp1\G
*************************** 1. row ***************************
Table: tb_emp1
Create Table: CREATE TABLE `tb_emp1` (
`id` int(11) DEFAULT NULL,
`name` varchar(25) DEFAULT NULL,
`deptId` int(11) DEFAULT NULL,
`salary` float DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)
【注】參考於清華大學出版社《MySQL資料庫應用案例課堂》2016年1月第1版