完整性性约束
1、实体完整性
主键约束: primary key
保证每一条记录的唯一性,字段的值必须是唯一的,且不能为null
一张表只能有一个主键,建议添加主键
2、域完整性
非空约束 not null
保证某一字段的值不能为 null
唯一性约束 unique
保证某一字段的值不能重复,可以为null,但是只能有1个
默认约束 default
在插入数据时,如果没有填写,提供默认值
3、自定义完整性
检查约束 check
mysql 不支持
4、引用完整性
外键约束 foreign key
一、主键
创建主键的三种方式:
1.创建表时,在字段描述处直接创建
eg:pid INT PRIMARY KEY,
2.创建表时,在constraint区域,创建指定字段为主键
eg:CONSTRAINT pk_person3 PRIMARY KEY(pid)
3.创建表后,通过修改表结构添加主键
eg:ALTER TABLE person6 ADD CONSTRAINT pk_p6 PRIMARY KEY(pid);
ALTER TABLE person6 ADD PRIMARY KEY(pid);
删除主键
ALTER TABLE person6 DROP PRIMARY KEY;
默认地,AUTO_INCREMENT 的开始值是 1,如果希望修改起始值,使用下列 SQL 语法:
ALTER TABLE Persons AUTO_INCREMENT=100
二、非空约束
创建表时,在字段描述后直接声明
eg:pname VARCHAR(20) NOT NULL,
注:使用数据库的工具软件时,给非空字段插入空值可能并不报错,只是警告,这显然是不正确的;而在命令行下操作不能插入数据,会明确提示该字段非空。
三、唯一性约束
创建唯一性约束也有三种方式,和主键约束完全一致
删除唯一性约束,须特别注意,使用如下SQL语句:
ALTER TABLE persons DROP INDEX
名称 ; 特别注意下划线部分,使用的是index,而不是unique