Mysql之约束

简介

Mysql之约束_第1张图片
not null前面也说过,这些约束是针对列的数据的,对应整个列的数据都起约束作用

基本但是创建表在字段后使用的语句

1.primary key-主键

Mysql之约束_第2张图片
Mysql之约束_第3张图片

==主键特征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','[email protected]');
INSERT INTO t17
	VALUES (2,'tom','tom.sohu.com')
INSERT INTO t17
	VALUES (1,'yuan','11.com')-- 如果执行完上面的,执行这行会报错
	因为id是主键,主键不能重而且不能为NULL!,之前有id=1的了,所以添加不成功

Mysql之约束_第4张图片

细节

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','[email protected]');
INSERT INTO t18
	VALUES (2,'tom','tom.sohu.com')
-- 上面正常操作
INSERT INTO t18
	VALUES (1,'cc','[email protected]');
--上一行也可以添加进去因为复合主键是两个都相同才不能添加
SELECT * FROM t18
INSERT INTO t18
	VALUES (1,'jack','[email protected]');
这个就报错了

查询
Mysql之约束_第5张图片
报错
Mysql之约束_第6张图片

2.主键可以在最后定义

CREATE TABLE t18(
	id INT ,
	`name` VARCHAR(32) ,
	email VARCHAR(32),
	PRIMARY KEY(`name`) -- 表定义最后指定主键
	);

3.使用desc查看表,可以看见主键情况
Mysql之约束_第7张图片

not null和unique

Mysql之约束_第8张图片

not null 前面的文章-Mysql数据库中的表
有讲

简而言之就是修饰的列类型不能为空
后面可以写成
NOT NULL DEFAULT 值
后面的值就是当为空时的默认值

UNIQUE
修饰的列数据
不能有相同的值
和主键不同的是
1.可以为NULL,且对应列的NULL不算重复,可以有多个NULL2.可以有多个unique字段3.可以把NOT NULL 和UNIQUE一起使用,达成类似主键的效果

forrign key-外键

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

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

细节

Mysql之约束_第11张图片
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

Mysql之约束_第12张图片

# 演示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

Mysql之约束_第13张图片

你可能感兴趣的:(Mysql,mysql,数据库,java)