当前位置:网站首页>MySql 约束
MySql 约束
2022-08-10 05:32:00 【hagong9】
目录
约束介绍
基本介绍
约束用于确保数据库的数据满足特定的商业规则。在mysql中,约束包括: not null、unique,primary key, foreign key,和check五种
主键 Primary key
1.用于定义唯一的标标示表行的数据,当主键约束后该列不能重复。
2.标示主键的列不能为空。
3,一个表中只能有一个主键,但可以是复合主键
4.主键1的指定方式有两种 直接在字段后指定 primary key,或在表定义最后写primary key(列名,列名,....)
5.在实际开发中,每个表往往都会设计一个主键。
-- 演示添加复合主键(id,和 name 做成复合主键)
CREATE TABLE t01
(`id` int,
`name` VARCHAR(10),
`email` VARCHAR(20),
PRIMARY KEY (id , `name`))-- 这里就是复合主键
复合主键的作用是,当往t01 表里添加 id 和name 时, 两个数值不能同时和表中的一条数据相同。
not null 非空 和unique 唯一
-- unqiue使用细节,和主键相似,但主键不能为空。
--如果没有指定not null ,则unique字段可以有多个nu1
--一张表可以有多个unique字段
foreign key 外键
如上图,jack和班级表的id=200发生了外键连接,那么直接删除id = 200的那条记录是会失败的,只有先把jack然后再删除 id= 200 才行。
-- 外键
CREATE TABLE my_class(
id INT PRIMARY KEY ,
`name` VARCHAR(10) not NULL DEFAULT '');
CREATE TABLE my_stu(
id INT PRIMARY KEY,
`name` VARCHAR(10) not NULL DEFAULT '',
class_id INT,
FOREIGN KEY (class_id) REFERENCES my_class(id)) -- 设置外键
-- 测试数据
INSERT INTO my_class
VALUES(100,'java'),(200,'web')
INSERT INTO my_stu
VALUES(1,'tom',100)-- 加入成功
INSERT INTO my_stu
VALUES(2,'som',200)-- 加入成功
INSERT INTO my_stu
VALUES(3,'rose',300)-- 加入失败
DELETE FROM my_class
WHERE id = 100 -- 删除失败
DELETE FROM my_class
WHERE id = 200 -- 删除失败
如果外键设置了没效果是因为数据库引擎的问题,应把在创建表时指定引擎为InnoDB
check
CREATE table ee
( `id` INT,
sex VARCHAR(4) CHECK (sex IN('man','woman')),
sal int CHECK (sal BETWEEN 1000 AND 2000))
ENGINE INNODB
INSERT INTO ee
VALUES (1,'man',1500)
INSERT INTO ee
VALUES (1,'xx',1500) -- 按道理这条语句不生效,可是用的是5,7版本只做语法的校验,check并不生效
约束练习
CREATE TABLE goods (
goods_id INT PRIMARY KEY auto_increment,
unitprice INT CHECK (sal BETWEEN 1 and 9999),
category VARCHAR(10),
provider VARCHAR(10))
ENGINE INNODB;
CREATE TABLE customer(
customer_id INT PRIMARY KEY auto_increment,
`name` VARCHAR(10) NOT null,
address VARCHAR(20),
email VARCHAR(20) UNIQUE,
sex ENUM('男','女') NOT NULL,
card_id int)
CHARACTER SET utf8 COLLATE utf8_bin ENGINE INNODB
CREATE TABLE purchase (
order_id INT PRIMARY KEY auto_increment,
customer_id INT,
goods_id INT,
nums INT,
FOREIGN KEY (customer_id) REFERENCES customer(customer_id),
FOREIGN KEY (goods_id) REFERENCES goods(goods_id))
边栏推荐
猜你喜欢
随机推荐
ResNet的基础:残差块的原理
各个架构指令集对应的机型
pytorch框架学习(3)torch.nn.functional模块和nn.Module模块
使用Google Protobuf 在 Matlab 中工作
论文精度 —— 2016 CVPR 《Context Encoders: Feature Learning by Inpainting》
Practical skills 19: Several postures of List to Map List
速刷正则表达式一周目(上)
网络安全5
训练集Loss收敛,但是测试集Loss震荡的厉害?
你不知道的常规流
Pony语言学习(九)——泛型与模式匹配(终章)
Touch chip used in smart touch remote control
使用Tenserboard可视化深度学习训练过程
matlab中的常用的类型转换
网络安全6
redis集群模式
树莓派入门(4)LED闪烁&呼吸灯
作业实验四
基于Qiskit——《量子计算编程实战》读书笔记(一)
Mockito基本使用指南