简介

 not null前面也说过,这些约束是针对列的数据的,对应整个列的数据都起约束作用
基本但是创建表在字段后使用的语句
1.primary key-主键

 
==主键特征1.对应列不能有重复的数据2.不能为NULL ==
 唯一且非空
-- 主键
-- id,name,email
CREATE TABLE t17(
	id INT PRIMARY KEY,-- 表示id列是主键
	`name` VARCHAR(32),
	email VARCHAR(32))
-- 主键列的值不能重复
INSERT INTO t17
	VALUES (1,'jack','jack@sohu.com');
INSERT INTO t17
	VALUES (2,'tom','tom.sohu.com')
INSERT INTO t17
	VALUES (1,'yuan','11.com')-- 如果执行完上面的,执行这行会报错
	因为id是主键,主键不能重而且不能为NULL!,之前有id=1的了,所以添加不成功
 

细节
1.一张表最多一个主键
 加入就是想要两个关键字不能同时相同
 有个复合主键
错误演示
CREATE TABLE t18(
	id INT PRIMARY KEY,-- 表示id列是主键
	`name` VARCHAR(32) PRIMARY KEY,
	email VARCHAR(32))
	报错,有两个主键
 
正确演示
CREATE TABLE t18(
	id INT ,
	`name` VARCHAR(32) ,
	email VARCHAR(32),
	PRIMARY KEY(id,`name`) -- 这里就是复合主键
	);
INSERT INTO t18
	VALUES (1,'jack','jack@sohu.com');
INSERT INTO t18
	VALUES (2,'tom','tom.sohu.com')
-- 上面正常操作
INSERT INTO t18
	VALUES (1,'cc','jack@sohu.com');
--上一行也可以添加进去因为复合主键是两个都相同才不能添加
SELECT * FROM t18
INSERT INTO t18
	VALUES (1,'jack','jack@sohu.com');
这个就报错了
 
查询
 
 报错
 
2.主键可以在最后定义
CREATE TABLE t18(
	id INT ,
	`name` VARCHAR(32) ,
	email VARCHAR(32),
	PRIMARY KEY(`name`) -- 表定义最后指定主键
	);
 
3.使用desc查看表,可以看见主键情况
 
not null和unique

not null 前面的文章-Mysql数据库中的表
 有讲
简而言之就是修饰的列类型不能为空
后面可以写成
NOT NULL DEFAULT 值
后面的值就是当为空时的默认值
 
UNIQUE
 修饰的列数据
 不能有相同的值
 和主键不同的是
 1.可以为NULL,且对应列的NULL不算重复,可以有多个NULL2.可以有多个unique字段3.可以把NOT NULL 和UNIQUE一起使用,达成类似主键的效果
forrign key-外键

 这个约束就是
 在我们有一个主表-定义好的
 我们想定义一个从表,但是这个从表有一个元素要和这个主表的对应元素(主键、unique)相匹配才能添加
 这时就可以用到外键了

 比如这两个表
 学生表的class_id必须和我们主表班级表
 的id想匹配才可以添加
 这个第三行数据就添加不成功,没有与其相匹配的班级的id
 主表(外键对应元素)一个元素可以对应多个从表对应数据
细节

 5.是对主表删除元素的限制
# 班级表-主表
# 学生表-从表
# 为了方便奥,我们把从表的定义外键类的数据列成为外键
# 而主表的对应外键的数据列叫主键
CREATE TABLE class(
		id INT PRIMARY KEY,
		`name` VARCHAR(32) NOT NULL DEFAULT '')
CREATE TABLE stu_02(
		id INT PRIMARY KEY,
		`name` VARCHAR(32) NOT NULL DEFAULT '',
		class_id INT,
		-- 下面定义外键关系
		FOREIGN KEY (class_id) REFERENCES class(id));-- class_id外键,id主键
INSERT INTO class
	VALUES (100,'java'),(200,'web');
	
SELECT * FROM class
INSERT INTO stu_02
	VALUES(1,'tom',100);
INSERT INTO stu_02
	VALUES(2,'jack',200);
-- 上面肯定能添加成功
INSERT INTO stu_02
	VALUES(3,'yuan',300);-- 该语句失败因为主键列没有300这个元素
INSERT INTO class
	VALUES(300,'php')-- 执行完这一行上面那一行就可以执行了
	
INSERT INTO stu_02
	VALUES(4,'ailun',100);	-- 主键的一个元素,可以包含对应外键多行数据(100班级,可以包含很多学生)
	
INSERT INTO stu_02
	VALUES(5,'666',NULL) -- 当允许为空时,外键可以为空
-- 有了主键外键关系的表,不能随意删除数据元素,只要主键有对应的外键数据,主键对应的数据行就不能删除
DELETE FROM class
	WHERE id = 100# 删除不成功,学生表里有100班的人,你不能100班就直接没了吧
SELECT * FROM stu_02 
 
要删主表对应元素
 要先删光从表对应数据行,然后就可以删除了
如果主表对应主键为unique修饰的可以为NULL
 如果包含NULL,其实NULL对应数据行也可以直接删除
CHECK

# 演示check
# mysql 5的版本,不支持check,只做语法检测不会生效
CREATE TABLE t23(
	id INT PRIMARY KEY,
	`name` VARCHAR(32),
	sex VARCHAR(6) CHECK(sex IN('man','woman')),
	sal DOUBLE CHECK(sal>1000 AND sal<2000)
	);
-- 添加数据
INSERT INTO t23
	VALUES (1,'tom','man',3000) -- 可以看到即使不符合CHECK的要求也能添加成功
	-- mysql5不支持CHECK
SELECT * FROM t23
 














![[RootersCTF2019]ImgXweb](https://img-blog.csdnimg.cn/f88b5736a6b649acaa912322789ced9e.png)





