简介
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