共计 3984 个字符,预计需要花费 10 分钟才能阅读完成。
这篇文章主要介绍“MySQL 表结构实例分析”的相关知识,丸趣 TV 小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL 表结构实例分析”文章能帮助大家解决问题。
约束条件
作用是限制如何给字段赋值
查看约束条件
mysql desc 库名. 表名;
mysql desc db1.t9;
// 如图所示,每列代表的含义:字段名 | 类型 | 空 | 键值 | 默认值 | 额外设置
mysql insert into t9 values (null,null,null);
// 如上图所示,约束条件允许为空(NULL),所以此处赋值的时候可以为空,null 不区分大小写
mysql select * from db1.t9;
mysql insert into db1.t9(name,sex) values( lucy , girl
mysql select * from db1.t9;
//t9 表的约束条件里,第三字段默认值为 NULL,也就是说当没有给第三字段赋值的时候,会以默认值填入表中,即如下图所示默认填入 NULL
设置约束条件
null // 允许为空(默认设置)
not null // 不允许为 null(空)
key // 键值类型
default // 设置默认值,缺省为 NULL
extra // 额外设置
mysql create database db2;
mysql create table db2.t1( - name char(10) not null default ,
- age tinyint unsigned default 19,
- sex enum(m , w) not null default m
- );
// 创建一个表 db2.t1,name 字段的类型为定长 char,约束条件是不允许为空,默认值为 0 个字符,显示效果入下图所示;age 字段的类型是微小整数 tinyint,约束条件是不允许为负数(unsigned),默认值设置为 19,注此处的默认值设置不得超过 tinyint 类型的范围,即默认值的设置不能超过 255;sex 字段的类型为枚举,enum 为单选,约束条件是不允许为空,默认值设置为 m;
mysql desc db2.t1;
mysql insert into db2.t1(name) values(bob
// 只给 name 字段赋值,剩下的字段由默认值赋值
mysql select * from db2.t1;
mysql insert into db2.t1 values( lucy , 21 , w // 给字段赋值,就不会以默认值赋值了
mysql select * from db2.t1;
mysql insert into db2.t1 values(null,null,null);
// 错误提示,name 字段不允许为空;name 和 sex 字段都不能为空
ERROR 1048 (23000): Column name cannot be null
mysql insert into db2.t1 values( null ,null, w
// null 的意思不再是空,仅仅是字符 null,没有空的含义了,所以可以给字段赋值
mysql insert into db2.t1 values( ,null, w
// 为 0 个字符,和空不一样,也可以给字段赋值
mysql select * from db2.t1;
总结
约束条件
类型
Null(是否允许为空 null)
默认允许 null
不允许为空 not null
Key(键值)
普通索引 index
唯一索引 unique
主键 primary key
外键 foreign key
全文索引 fulltext
Default(默认值:不给字段赋值使用默认值赋值)
默认不定义时是 null
定义时是 default(要与字段类型匹配)
Extra(额外设置:默认都没有额外设置)
修改表结构
语法结构
用法
mysql alter table 库名. 表名 执行动作;
执行动作
add 添加字段
modify 修改字段类型
change 修改字段名
drop 删除字段
rename 修改表名
添加新字段
用法
—— 新字段默认添加在字段末尾
mysql alter table 库名. 表名 add 字段名 类型(宽度) 约束条件;
add 字段名 类型 [约束条件] after 字段名;
add 字段名 类型 [约束条件] first;
不指定位置添加字段
mysql alter table db2.t1 add email varchar(50); // 不指定添加字段的位置,默认就在末尾
mysql desc db2.t1;
在某一字段后面添加字段
mysql alter table db2.t1 add hobby set(eat , drink , play , happy) not null default eat,drink after age; // 指定添加位置在字段 age 之后,条件设置不允许为空,并设置默认值为 eat,drink
mysql desc db2.t1;
mysql select * from db2.t1;
// 查看表内容,发现 hobby 字段自动添加了默认值
将字段添加到最前面
mysql alter table db2.t1 add class char(7) default B180601 first; // 将字段 class 添加到最前面
mysql desc db2.t1;
mysql select * from db2.t1; //class 字段自动添加默认值
修改字段类型
基本用法
—— 修改的字段类型不能与已存储的数据冲突
mysql alter table 库名. 表名 modify 字段名 类型(宽度) 约束条件;
modify 字段名 类型 [约束条件] after 字段名;
modify 字段名 类型 [约束条件] first;
注:
如果表中这个字段类型下面的字段已经有值了,那么修改的类型与约束不能与字段里面已经存储的数据发生冲突,如果发生冲突则不允许修改。比如,有一个字段 name,里面存储了一个数据为 bob,那么把字段的类型 (宽度) 改成 char(1),则会修改失败,因为 bob 的宽度为 3,如果将字段的类型 (宽度) 改为 char(1),则源数据 bob 就存不下了,由于已存储的数据优先,所以就不能进行修改;
修改字段的类型时要注意,不修改的部分要原样进行抄写,如果不修改的部分不原样抄写,那就相当于对其进行还原即使用默认配置。比如有一个字段 name,他的类型是 char(10),约束条件是不允许为空,默认值是,现在要将其类型宽度改为 char(20),其余没修改的部分没有在命令中进行原样抄写,那么输出结果该字段的约束条件会变为默认情况,即允许为空,默认值为 NULL。改变字段位置的时候也一样。
mysql desc db2.t1;
将字段 age 的位置修改到字段 class 的后面
mysql alter table db2.t1 modify age tinyint unsigned default 19 after class; // 除了对字段 age 的位置进行了修改,其余不修改的地方如:类型(宽度)、约束条件进行原样抄写
mysql desc db2.t1;
将字段 name 的类型变为 varchar(15)
mysql alter table db2.t1 modify name varchar(15) not null default
mysql desc db2.t1;
修改字段名
基本用法
—— 也可以用来修改字段类型
mysql alter table 库名. 表名 change 源字段名 新字段名 类型(宽度) 约束条件;
注:也可以用来修改类型和约束条件,只需要写上新的类型和新的约束条件即可
mysql desc db2.t1;
将字段名 email 修改为 mail
mysql alter table db2.t1 change email mail varchar(50);
mysql desc db2.t1;
将字段名 mail 修改为 email,并修改约束条件
mysql alter table db2.t1 change mail email varchar(50) not null default njw@163.com // 出现错误,因为源数据中,mail 字段中的值为 NULL,如果将约束条件修改为 not null,那么就与源数据发生冲突,所以修改失败
ERROR 1138 (22004): Invalid use of NULL value
mysql alter table db2.t1 change mail email varchar(50) default njw@163.com
mysql desc db2.t1;
删除字段
基本用法
mysql alter table 库名. 表名 drop 字段名;
mysql alter table db2.t1 drop email; // 删除库 db2 中表 t1 的字段 email
mysql desc db2.t1; // 没有字段 email,已被删除
mysql select * from db2.t1; // 字段 email 及其数据已被删除
修改表名
基本用法
mysql alter table 库名. 表名 rename 新表名;
库名. 新表名;
mysql use db2;
mysql show tables;
mysql alter table db2.t1 rename stuinfo; // 将表名修改为 stuinfo
mysql show tables;
mysql select * from stuinfo;
关于“MySQL 表结构实例分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注丸趣 TV 行业资讯频道,丸趣 TV 小编每天都会为大家更新不同的知识点。