意见箱
恒创运营部门将仔细参阅您的意见和建议,必要时将通过预留邮箱与您保持联络。感谢您的支持!
意见/建议
提交建议

MySQL表结构实例分析

来源:恒创科技 编辑:恒创科技编辑部
2023-12-17 06:07:59

这篇文章主要介绍“MySQL表结构实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL表结构实例分析”文章能帮助大家解决问题。

约束条件

作用是限制如何给字段赋值


MySQL表结构实例分析

查看约束条件

mysql> desc 库名.表名;

mysql>descdb1.t9;

//如图所示,每列代表的含义:字段名 | 类型 | 空 | 键值 | 默认值 | 额外设置

mysql>insertintot9values(null,null,null);

//如上图所示,约束条件允许为空(NULL),所以此处赋值的时候可以为空,null不区分大小写

mysql>select*fromdb1.t9;

mysql>insertintodb1.t9(name,sex)values("lucy","girl");
mysql>select*fromdb1.t9;

//t9表的约束条件里,第三字段默认值为NULL,也就是说当没有给第三字段赋值的时候,会以默认值填入表中,即如下图所示默认填入NULL

设置约束条件

null //允许为空(默认设置)

not null //不允许为null(空)

key //键值类型

default //设置默认值,缺省为NULL

extra //额外设置

mysql>createdatabasedb2;
mysql>createtabledb2.t1(
->namechar(10)notnulldefault"",
->agetinyintunsigneddefault19,
->sexenum("m","w")notnulldefault"m"
->);

//创建一个表db2.t1,name字段的类型为定长char,约束条件是不允许为空,默认值为0个字符,显示效果入下图所示;age字段的类型是微小整数tinyint,约束条件是不允许为负数(unsigned),默认值设置为19,注此处的默认值设置不得超过tinyint类型的范围,即默认值的设置不能超过255;sex字段的类型为枚举,enum为单选,约束条件是不允许为空,默认值设置为m;

mysql> desc db2.t1;

mysql>insertintodb2.t1(name)values("bob");

//只给name字段赋值,剩下的字段由默认值赋值

mysql>select*fromdb2.t1;

mysql>insertintodb2.t1values("lucy","21","w");//给字段赋值,就不会以默认值赋值了
mysql>select*fromdb2.t1;

mysql>insertintodb2.t1values(null,null,null);
//错误提示,name字段不允许为空;name和sex字段都不能为空
ERROR1048(23000):Column'name'cannotbenull
mysql>insertintodb2.t1values("null",null,"w");
//"null"的意思不再是空,仅仅是字符null,没有空的含义了,所以可以给字段赋值
mysql>insertintodb2.t1values("",null,"w");
//""为0个字符,和空不一样,也可以给字段赋值
mysql>select*fromdb2.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>altertabledb2.t1addemailvarchar(50);//不指定添加字段的位置,默认就在末尾
mysql>descdb2.t1;

在某一字段后面添加字段

mysql>altertabledb2.t1addhobbyset("eat","drink","play","happy")notnulldefault"eat,drink"afterage;//指定添加位置在字段age之后,条件设置不允许为空,并设置默认值为eat,drink
mysql>descdb2.t1;

mysql>select*fromdb2.t1;//查看表内容,发现hobby字段自动添加了默认值

将字段添加到最前面

mysql>altertabledb2.t1addclasschar(7)default"B180601"first;//将字段class添加到最前面
mysql>descdb2.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>altertabledb2.t1modifynamevarchar(15)notnulldefault"";
mysql>descdb2.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>altertabledb2.t1changemailemailvarchar(50)notnulldefault"njw@163.com";//出现错误,因为源数据中,mail字段中的值为NULL,如果将约束条件修改为notnull,那么就与源数据发生冲突,所以修改失败
ERROR1138(22004):InvaliduseofNULLvalue
mysql>altertabledb2.t1changemailemailvarchar(50)default"njw@163.com";
mysql>descdb2.t1;

删除字段

基本用法

mysql> alter table 库名.表名 drop 字段名;

mysql>altertabledb2.t1dropemail;//删除库db2中表t1的字段email
mysql>descdb2.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表结构实例分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注恒创行业资讯频道,小编每天都会为大家更新不同的知识点。

上一篇: concat(round(sum(DATA_LENGTH/1024/1024),2),'M') 下一篇: MySQL数据库基础知识点有哪些