表的约束很多,这里主要介绍如下几个: null/not null,default, comment, zerofill,primary,key,auto_increment,unique key 。
通过select可以看到null的值为null。
由于空值无法参与运算,因此null值加一后得到的还是null。
案例:
创建一个班级表,包含班级名和班级所在的教室。
站在正常的业务逻辑中:
- 如果班级没有名字,你不知道你在哪个班级;
- 如果教室名字可以为空,就不知道在哪上课。
所以我们在设计数据库表的时候,一定要在表中进行限制,满足上面条件的数据就不能插入到表中。这就是“约束”。
创建一个班级表,表当中包含班级名和该班级所在的教室,如果插入数据时不想让这两个字段为空,就可以在创建表时给这两个字段设置not null属性。
创建表完成以后,查看表结构,可以发现这两个字段是不为空的。
向表中插入记录时只有这两个字段都不为空时才能插入成功,否则将会插入失败。
创建一个用户表,表当中包含用户的姓名、年龄和性别,将用户的年龄默认设置成0,将用户的性别默认设置成男。
创建表完成以后,默认值就已经设置成功了。
如果此时在表中插入数据,如果我们不插入,就会显示默认值;
同时设置not null和default
创建一个表,表当中包括姓名和id,将id同时设置default和not null属性。
查看表结构,我们会发现id字段不允许为null,默认值为1。
此时向表中插入值,如果不插入id值,就会默认为1。
列描述:comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或DBA来进行了解。
创建一个用户表,表当中包含用户名、用户的年龄和用户的性别,在每一个字段后面添加上对应的列描述。
创建表完毕后,通过show create table
表名SQL可以看到创建表时的相关细节,包括列描述。
数值类型后面的圆括号中的数字,代表的是显示宽度,对应数值类型设置zerofill属性后,如果数据的宽度小于设定的宽度则自动填充0。
创建一个表,将表中数据的显示宽度设置为5,但是没有设置zerofill属性。
此时在a和b列插入数据,并没有什么变化。
我们将a列的属性添加上zerofill属性以后,由于a列数据的显示宽度为5,因此查看表中数据可以看到a列数据中宽度不足5位的数据都自动在前面填充0了。
注意,zerofill属性的作用就是让数据以特定的方式进行显示而已,数据底层的储存方式并没有发生变化,通过hex函数可以看到a列中显示的00001在底层实际储存的还是1。
可以看出数据库内部存储的还是1,00001只是设置了zerofill属性后的一种格式化输出而已。
主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键所在的列通常是整数类型。
创建一个学生表,表当中包含学生的学号和姓名,由于学生的学号是不会重复的,因此可以将其设置成主键。
创建表成功后查看表结构,可以看到id对应的Key列出现了PRI,这表示我们已经成功将学号设置成这张表的主键了。此外,虽然在创建表的时候没有给学号设置not null属性,但由于主键本身就是不能为空的,因此id默认也就不能为空了。
所谓的主键约束就是,插入表中的记录的主键字段不能重复,如果插入记录的主键与表中已有记录的主键重复,这时就会因为主键冲突而插入失败。
使用 alter table 表名 drop primary key
SQL即可删除指定表的主键,因为一个表只有一个主键,因此删除主键时只用指明要删除哪张表的主键即可。比如这里删除学生表的主键后再查看表结构,可以看到id对应的Key列的PRI已经没有了。
对于已经创建好了的表,使用 alter table 表名 add primary key(列名)
SQL可以给指定列设置成主键,但是需要注意的是,只有列当中的值不为空并且不重复的列才能被设置成主键。比如这里重新将学号设置成学生表的主键后再查看表结构,可以看到id对应的Key列的PRI又回来了。
复合主键
创建一个表,表当中包含id,course和score组合起来形成一个复合主键。
表创建完毕后查看表结构,可以看到id和course的Key列都有PRI标志,并且它们都是不允许为空的。
在向表中插入数据时,只有插入id和course均出现冲突时才会产生主键冲突,否则就允许插入。
查看表中的数据我们可以看见,id可以是重复的,course也可以是重复的,但是id和course不可以同时是重复的,这就是复合主键的作用。
使用alter table 表名 drop primary key
SQL可以删除指定表的复合主键,比如这里删除进程表的复合主键后再查看表结构,可以看到id和course对应的Key列的PRI都没有了。
对于已经创建好了的表,也可以使用alter table 表名 add primary key(多个列名)
SQL用多个列形成复合主键,但是需要注意的是,被选取的多个列当中的值不能为空并且不能同时出现重复。比如这里重新将id和course设置成进程表的复合主键后再查看表结构,可以看到id和course对应的Key列的PRI又回来了。
auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。
自增长的特点:
创建一个表,表当中包含id和name,将id同时设置成主键和自增长字段。
创建表完毕后查看表结构,可以看到id的Extra列中出现了auto_increment标志。
向表中插入第一条记录时如果没有指明自增长字段的值,那么自增长字段的值默认将会从1开始,后续向表中插入记录时如果也不指明自增长字段的值,那么自增长字段的值就会依次递增。
当然,插入记录的时候也可以指明自增长字段的值,此时将会使用该值进行插入,但注意指明的值不能和表中已有的id值重复,此后向表中插入记录时如果又不指明自增长字段的值,那么自增长字段的值将会从id列中找出最大值,将最大值加一后得到的值作为自增长字段的值进行插入。
索引:
创建一个学生表,表当中包含学生的id、姓名和电话号码,将我们选择id作为主键,但同时每个学生的电话号码也应该具有唯一性约束,因此应该将电话号码设置成唯一键。
表创建完毕后查看表结构,可以看到number的Key列出现了UNI标志,这就表明number已经成功被设置成唯一键了。
向表中插入记录时,如果插入记录中的电话号码与表中已有记录的电话号码出现重复,那么就会因为唯一键冲突而插入失败。
向表中插入的记录可以不指明唯一键字段的值,此时该字段默认为空,不做唯一性比较。
外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique
约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。
先创建一个班级表作为主表,表当中包含班级的id和班级名,并将班级id设置为主键。
再创建一个学生表作为从表,表当中包含学生的id、姓名以及学生所在班级对应的id,并将学生表中的班级id列设置成外键,关联到班级表中的班级id列。
表创建完毕后查看学生表的表结构,可以看到学生表中的班级id对应的Key列出现了MUL标志,这表明class_id已经成功被设置成了外键。
我们先向班级表中插入两条记录。
这时向学生表中插入记录时,如果插入的记录对应的班级id是班级表中存在的,或者插入的班级id为null,那么此时是允许进行插入的。
如果插入学生表的记录对应的班级id是103,相当于插入学生表的这条记录对应的班级并不存在,此时将会插入失败,这就是外键约束。
这时如果向班级表中插入班级id为103的班级信息,然后再向学生表中插入上述记录,这时就允许插入了。