Mysql之约束

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

简介

在这里插入图片描述
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

在这里插入图片描述

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: mysql