真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务
逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的。
表的约束很多,这里主要介绍如下几个: null/not null,default, comment, zerofill,primary key,auto_increment,unique key 。
1、空属性
两个值:null(默认的),not null(不为空)
数据库默认字段基本都是字段为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运
算。
案例:
创建一个班级表,包含班级名和班级所在的教室。
站在正常的业务逻辑中:
如果班级没有名字,你不知道你在哪个班级
如果教室名字可以为空,就不知道在哪上课
所以我们在设计数据库表的时候,一定要在表中进行限制,满足上面条件的数据就不能插入到表中。这就是“约束”。
创一个表name字段不为空
create table dp1(id int,name varchar(20 not null));
插入数据有那么字段的数据可以可以插入但是没有那么字段的就不能插入了
显示id为1的name为lisan的可以插入但是当只插入id时就显示name不是一个默认值就是name不能控
2、默认值
默认值:某一种数据会经常性的出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,用户可以选择
性的使用默认值。但设置为null默认值就为0了,但是某一个字段不为空时就没有了默认值了。
创建一个id字段和name字段不为空age为默认值100的表
create table dp3(id int not null,name varchar(20) not null,age intunsigneddefault100);
图片显示当插入id字段和name字段时没有插入age字段是可以正常插入但是当给age插入101时也能插入
结果显示当给age不插入数据时age为默认值100但是当给插入新数据时下新数据就会覆盖原始数据
只有设置了default的列,才可以在插入值的时候,对列进行省略
3、列描述
列描述:comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或DBA来进行了
解。
创建一个id描述为编号 name描述为名字age描述为年龄
create table dp5(id int not null comment "bianhao",name varchar(20) not null comment "minzi",age intunsigneddefault100 comme;nt "nianling");
4、zerofill
创建一个具有两个字段的表,两个字段数据类型都是int(10);
create table dp7(a int(10)default null,b int(10)default null);
可以看到int(10),这个代表什么意思呢?整型不是4字节码?这个10又代表什么呢?其实没有zerofill这个属性,括号内
的数字是毫无意义的。a和b列就是前面插入的数据,如下:
但是对一个字段增加了zerofill属性结果就不同了
可以看出当给a插入1和200时就会出现前边就会出现0为什么呢?因为在创建表时设置了字段的宽度当插入的数字宽带小于设置的字段宽度时就会自动填充0,上图就是最后结果在MySQL中实际存储的还是1。为什么是这样呢?我们可以用hex函数来证明。
可以看出数据库内部存储的还是1,00001只是设置了zerofill属性后的一种格式化输出而已。
5、主键
主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键
所在的列通常是整数类型。
创建一个表编号为这张表的主键
create table dp9(a int(10) primary key,b int(10)default null);
首先当插入重复的值时
显示a为主键已经有了不能插入同样的数据了
当不给a插入数据时
显示a没有有一个默认值所以主键不能为空
总结:
首先主键不能为空,其次主键不能重复
主键的修改
创建一个没有主键的表
create table student(id int,name varchar(30));
给id添加为主键
alter table 表名 add primary key(字段列表)
create table student(id int,name varchar(30));
删除主键
删除刚刚添加给id的主键
alter table student drop primary key;
显示这个表已经没有了主键
复合主键
在创建表的时候,在所有字段之后,使用primary key(主键字段列表)来创建主键,如果有多个字段作为主键,
可以使用复合主键。
创建一个student表设置id和学号为复合主键
create table student1(id int, xuehao varchar(12),name varchar(30),primary key(id,xuehao));
图片显示id和学号已经被设置为主键了
添加数据
首先添加一组数据
接着添加id’和学号相同的数据
结果显示id-xuehao为key不能重复,显示主键冲突
接着分别添加id相同但是学号不同的数据或者id不同但是学号相同的一组数据
结果显示添加成功,这就说明id-xuehao共同组成这个表的主键,缺一不可
6、自增长
auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得
到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。
自增长的特点:
任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)
自增长字段必须是整数
一张表最多只能有一个自增长
创建一个表id为主键而且自增长
create table student3(id int auto_increment,name varchar(32));
只插入字段name的值不插入id字段的值
结果显示id中的值随插入的值一直自增1,在插入后获取上次插入的 AUTO_INCREMENT 的值(批量插入获取的是第一个值
索引:
在关系数据库中,索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结构,它是某个表中
一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。索引的作用相当于图书的目录,
可以根据目录中的页码快速找到所需的内容。
索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序。数据库使用索引以
找到特定值,然后顺指针找到包含该值的行。这样可以使对应于表的SQL语句执行得更快,可快速访问数据库表中的
特定信息。
7、唯一键
首先说明的是唯一键不是主键
一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多
个字段需要唯一性约束的问题。
唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。
关于唯一键和主键的区别:
我们可以简单理解成,主键更多的是标识唯一性的。而唯一键更多的是保证在业务上,不要和别的信息出现重复。乍
一听好像没啥区别。
创建一个id为唯一键
create table student5(id int unique,name varchar(10));
图片显示当插入数据和唯一键相同时就会显示id为唯一键冲突
但是不给唯一键添加数据时显示就会添加成功
结果显示当不给唯一键不插入数据时就会为NULL。
8、外键
创建一个主表id为主键
create table dp2(id int primary key,name varchar(32));
创建一个从表主键为id,外键为dp_id
create table dp(id int primary key,name varchar(32),dp_id int,foreign key(dp_id) references dp2(id));
往主表中插入数据
往从表中插入数据时因为主表中对应从表中没有的外键数据显示插入失败但是如果存在就显示插入成功
如何理解外键约束
首先我们承认,这个世界是数据很多都是相关性的。
理论上,上面的例子,我们不创建外键约束,就正常建立学生表,以及班级表,该有的字段我们都有。
此时,在实际使用的时候,可能会出现什么问题?
有没有可能插入的学生信息中有具体的班级,但是该班级却没有在班级表中?
因为此时两张表在业务上是有相关性的,但是在业务上没有建立约束关系,那么就可能出现问题。
解决方案就是通过外键完成的。建立外键的本质其实就是把相关性交给mysql去审核了,提前告诉mysql表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入。
版权归原作者 自首的小偷 所有, 如有侵权,请联系我们删除。