对表中的数据进行限定,保证数据的正确性、有效性和完整性
限定某个字段/某列的值不允许为空
空字符串’'不等于NULL,0也不等于NULL
CREATE TABLE 表名称(
字段名 数据类型,
字段名 数据类型 NOT NULL,
字段名 数据类型 NOT NULL
);
#添加not null
ALTER TABLE 表名称 MODIFY 字段名 数据类型 NOT NULL;
#去掉not null,相当于修改某个非注解字段,该字段允许为空
ALTER TABLE 表名称 MODIFY 字段名 数据类型
用来限制某个字段/某列的值不能重复
特点
CREATE TABLE 表名称(
字段名 数据类型, 字段名 数据类型 UNIQUE,
字段名 数据类型 UNIQUE KEY, 字段名 数据类型
);
CREATE TABLE 表名称(
字段名 数据类型,
字段名 数据类型,
字段名 数据类型,
[CONSTRAINT 约束名] UNIQUE KEY(字段名)
);
# 指定唯一键约束
# 方式一:
ALTER TABLE 表名称 ADD UNIQUE KEY(字段列表);
# 方式二:
ALTER TABLE 表名称 MODIFY 字段名 字段类型 UNIQUE;
用来唯一标识表中的一行记录
特点
CREATE TABLE 表名称(
字段名 数据类型 PRIMARY KEY, #列级模式
字段名 数据类型,
字段名 数据类型
);
CREATE TABLE 表名称(
字段名 数据类型,
字段名 数据类型,
字段名 数据类型,
[CONSTRAINT 约束名] PRIMARY KEY(字段名) #表级模式
);
ALTER TABLE 表名称 ADD PRIMARY KEY(字段列表); #字段列表可以是一个字段,也可以是多个字段,如果是多 个字段的话,是复合主键
ALTER TABLE 表名称 ADD PRIMARY KEY(字段名1,字段名2);
某个字段的值自增
特点
-- 建表
CREATE TABLE 表名称(
字段名 数据类型 PRIMARY KEY AUTO_INCREMENT,
字段名 数据类型 UNIQUE KEY not null,
字段名 数据类型 UNIQUE KEY,
字段名 数据类型 NOT NULL DEFAULT 默认值
);
CREATE TABLE 表名称(
字段名 数据类型 DEFAULT 默认值 ,
字段名 数据类型 UNIQUE KEY AUTO_INCREMENT,
字段名 数据类型 NOT NULL DEFAULT 默认值,
PRIMARY KEY(字段名)
);
-- 增加自增约束
ALTER TABLE 表名称 MODIFY 字段名 数据类型 AUTO_INCREMENT;
-- 删除自增约束,去掉auto_increment相当于删除
ALTER TABLE 表名称 MODIFY 字段名 数据类型;
说明:
限定某个表的某个字段的引用完整性
特点
CREATE TABLE 主表名称(
字段1 数据类型 PRIMARY KEY,
字段2 数据类型
);
CREATE TABLE 从表名称(
字段1 数据类型 PRIMARY KEY,
字段2 数据类型,
[CONSTRAINT <外键约束名称>] FOREIGN KEY(从表的某个字段) REFERENCES 主表名(被参考字段)
);
#(从表的某个字段)的数据类型必须与主表名(被参考字段)的数据类型一致,逻辑意义也一样
#(从表的某个字段)的字段名可以与主表名(被参考字段)的字段名一样,也可以不一样
-- FOREIGN KEY: 在表级指定子表中的列
-- REFERENCES: 标示在父表中的列
约束等级
备注:外键与级联更新适用于单机低并发 ,不适合分布式 、 高并发集群 ;级联更新是强阻塞,存在数据库更新风暴的风险;外键影响数据库的 插入速度 。
检查某个字段的值是否符号xx要求,一般指的是值的范围
MySQL5.7 可以使用check约束,但check约束对数据验证没有任何作用。添加数据时,没有任何错误或警告,但是MySQL 8.0中可以使用check约束了。
实例
CREATE TABLE employee(
eid INT PRIMARY KEY,
ename CARCHAR(5),
gender CHAR CHECK ('男' or '女')
);
给某个字段/某列指定默认值,一旦设置默认值,在插入数据时,如果此字段没有显式赋值,则赋值为默
认值。
CREATE TABLE 表名称(
字段名 数据类型 PRIMARY KEY,
字段名 数据类型 UNIQUE KEY NOT NULL,
字段名 数据类型 UNIQUE KEY,
字段名 数据类型 NOT NULL DEFAULT 默认值,
);
# 在给某个字段加非空约束也一样,如果这个字段原来有默认值约束,你想保留,也要在modify语句中保留默 认值约束,否则就删除了
ALTER TABLE 表名称 MODIFY 字段名 数据类型 DEFAULT 默认值;
ALTER TABLE 表名称 MODIFY 字段名 数据类型 DEFAULT 默认值 NOT NULL;
说明:默认值约束一般不在唯一键和主键列上加