Mysql命令desc:获取数据表结构
2016-06-04 07:54
435 查看
desc命令用于获取数据表结构。
desc命令格式:
desc 表名;
同样
show columns from 表名;
也能获取数据表结构。
举例如下:
mysql> desc MyClass;
mysql> show columns from MyClass;
使用MySQL数据库desc 表名时,我们看到Key那一栏,可能会有4种值,即 ' ','PRI','UNI','MUL'。
如果Key是空的,那么该列值的可以重复,表示该列没有索引,或者是一个非唯一的复合索引的非前导列;
如果Key是PRI,那么该列是主键的组成部分;
如果Key是UNI,那么该列是一个唯一值索引的第一列(前导列),并别不能含有空值(NULL);
如果Key是MUL,那么该列的值可以重复,该列是一个非唯一索引的前导列(第一列)或者是一个唯一性索引的组成部分但是可以含有空值NULL。
如果对于一个列的定义,同时满足上述4种情况的多种,比如一个列既是PRI,又是UNI,那么"desc 表名"的时候,显示的Key值按照优先级来显示 PRI->UNI->MUL。那么此时,显示PRI。
一个唯一性索引列可以显示为PRI,并且该列不能含有空值,同时该表没有主键。
一个唯一性索引列可以显示为MUL,如果多列构成了一个唯一性复合索引,因为虽然索引的多列组合是唯一的,比如ID+NAME是唯一的,但是没一个单独的列依然可以有重复的值,只要ID+NAME是唯一的即可。
desc命令格式:
desc 表名;
同样
show columns from 表名;
也能获取数据表结构。
举例如下:
mysql> desc MyClass;
mysql> show columns from MyClass;
使用MySQL数据库desc 表名时,我们看到Key那一栏,可能会有4种值,即 ' ','PRI','UNI','MUL'。
如果Key是空的,那么该列值的可以重复,表示该列没有索引,或者是一个非唯一的复合索引的非前导列;
如果Key是PRI,那么该列是主键的组成部分;
如果Key是UNI,那么该列是一个唯一值索引的第一列(前导列),并别不能含有空值(NULL);
如果Key是MUL,那么该列的值可以重复,该列是一个非唯一索引的前导列(第一列)或者是一个唯一性索引的组成部分但是可以含有空值NULL。
如果对于一个列的定义,同时满足上述4种情况的多种,比如一个列既是PRI,又是UNI,那么"desc 表名"的时候,显示的Key值按照优先级来显示 PRI->UNI->MUL。那么此时,显示PRI。
一个唯一性索引列可以显示为PRI,并且该列不能含有空值,同时该表没有主键。
一个唯一性索引列可以显示为MUL,如果多列构成了一个唯一性复合索引,因为虽然索引的多列组合是唯一的,比如ID+NAME是唯一的,但是没一个单独的列依然可以有重复的值,只要ID+NAME是唯一的即可。
相关文章推荐
- Mysql命令create table:创建数据表
- Mysql命令select:当前选择(连接)的数据库
- Mysql命令use:使用数据库
- Mysql命令show databases:显示所有数据库
- Mysql命令create:创建数据库
- Mysql命令grant on:增加新用户并控制其权限
- Mysql命令mysqladmin:修改用户密码
- Mysql命令mysql:连接Mysql数据库
- MySql均衡负载
- 【Mysql sql inject】【入门篇】sqli-labs使用 part 3【15-17】
- mssql数据迁移到mysql
- mysql索引和分表
- 最全的mysql查询语句整理
- MySQL查询语句大全集锦
- mysql远程访问速度慢的解决方案
- mysql免密码登陆
- mysql优化
- Mysql命令
- servlet向mysql插入中文时乱码解决
- MySQL学习笔记之十:使用mysql-proxy实现MySQL读写分离