数据库的约束有:1、主键约束;2、非空约束;3、自增长约束;4、非负约束;5、少数约束;6、外键约束。主键约束是指,主键修饰的字段,非空且少数,一张表中只能有一个主键。
1、主键约束
主键约束在表中定义一个主键来少数确定表中每一行数据的标识符。
特点:
- 主键约束相当于少数性约束+ 非空约束,主键约束不允许重复,也不允许出现空值;
- 一个表非常多只能有一个主键约束,建立主键约束可以在列级别创建,也可以再表级别创建;
- 主键约束对应着表中的一列或者多列,对应着多列的时候就是复合主键(可以类比我们之前讲过的复合少数性约束);
- 如果是多列组合的复合主键约束,那么这些列都不允许为空值,并且组合的值也不允许重复;
- MySQL中的主键约束名永远都是PRIMARY,就算我们自己命名了主键约束名,这个时候主键约束名也还是PRIMARY,不会改变;
- 当创建主键约束时,系统默认会在主键约束所在的列或者列组合上建立对应的主键索引,如果删除主键约束,那么主键索引也就自动删除了。当一个表中有主键约束时,系统会默认根据主键约束对应的主键索引来构建一个B+tree的结构,用于存储表中的数据,在这种B+tree的结构下查询的效率更高;
- 需要注意:不要修改主键字段的值,因为主键是数据记录的少数标识,如果修改了主键的值,就有可能会破坏数据的完整性。
2、非空约束
非空约束指的是表中的某一个字段的内容不允许为空,如果要使用非空约束,只需要在每个列的后面利用“NOT NULL”声明即可。
特点:
- 默认,所有的类型的值都可以是NULL,包括INT、FLOAT等数据类型
- 非空约束只能出现在表对象的列上,只能某个列单独限定非空,不能组合非空
- 一个表可以有很多列都分别限定了非空
- 空字符串’’不等于NULL,0也不等于NULL
3、自增长约束
在 MySQL 中,当主键定义为自增长后,这个主键的值就不再需要用户输入数据了,而由数据库系统根据定义自动赋值。每增加一条记录,主键会自动以相同的步长进行增长。
特点:
- 默认情况下,auto_increment的初始值是 1,每新增一条记录,字段值自动加 1。
- 一个表中只能有一个字段使用 auto_increment约束,且该字段必须有少数索引,以避免序号重复(即为主键或主键的一部分)。
- auto_increment约束的字段必须具备 NOT NULL 属性。
- auto_increment约束的字段只能是整数类型(TINYINT、SMALLINT、INT、BIGINT 等。
- auto_increment约束字段的最大值受该字段的数据类型约束,如果达到上限,auto_increment就会失效。
4、非负约束
指定某列不可存储负值,添加非负约束后,取值范围将发生变化,例如int范围是-128~127,添加非负约束后将变成0-255。
5、少数约束
少数约束(Unique Key)是指所有记录中字段的值不能重复出现。例如,为 id 字段加上少数性约束后,每条记录的 id 值都是少数的,不能出现重复的情况。少数约束保证在一个字段或者一组字段里的数据与表中其它行的数据相比是少数的。
少数约束SQL实现:
CREATE TABLE OnlyConstraint
(ConstraintColumnOne VARCHAR(20) NOT NULL UNIQUE,
ConstraintColumnTwo VARCHAR(20) NOT NULL,
CONSTRAINT UK_OnlyConstraint_ConstraintColumnTwo UNIQUE(ConstraintColumnTwo) )
GO
6、外键约束
FOREIGN KEY是表的一个特殊字段,经常与主键约束一起使用。对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表(父表),外键所在的表就是从表(子表)。外键用来建立主表与从表的关联关系,为两个表的数据建立连接,约束两个表中数据的一致性和完整性。
定义外键时,需要遵守下列规则:
- 主表必须已经存在于数据库中,或者是当前正在创建的表。如果是后一种情况,则主表与从表是同一个表,这样的表称为自参照表,这种结构称为自参照完整性。
- 必须为主表定义主键。
- 主键不能包含空值,但允许在外键中出现空值。也就是说,只要外键的每个非空值出现在指定的主键中,这个外键的内容就是正确的。
- 在主表的表名后面指定列名或列名的组合。这个列或列的组合必须是主表的主键或候选键。
- 外键中列的数目必须和主表的主键中列的数目相同。
- 外键中列的数据类型必须和主表主键中对应列的数据类型相同。
延伸阅读
数据库的三大范式
- 名列前茅范式:当关系模式R的所有属性都不能在分解为更基本的数据单位时,称R是满足名列前茅范式的,简记为1NF。满足名列前茅范式是关系模式规范化的最低要求,否则,将有很多基本操作在这样的关系模式中实现不了。
- 第二范式:如果关系模式R满足名列前茅范式,并且R得所有非主属性都完全依赖于R的每一个候选关键属性,称R满足第二范式,简记为2NF。
- 第三范式:设R是一个满足名列前茅范式条件的关系模式,X是R的任意属性集,如果X非传递依赖于R的任意一个候选关键字,称R满足第三范式,简记为3NF。
文章标题:数据库的约束有哪些,发布者:Z, ZLW,转载请注明出处:https://worktile.com/kb/p/34588