数据库:约束

概述:

概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据。

目的:保证数据库中数据的正确、有效性和完整性。

分类

约束是作用于表中的字段上的,在创建/修改表时可以添加约束

演示

创建表:

sql 复制代码
create table students(
    id int primary key auto_increment comment '学号',
    name varchar(20) not null unique comment '姓名',
    age int check ( age between 0 and 100) comment '年龄',
    staus char(1) default '1' comment '状态',
    gender char(1) comment '性别'
    )comment '学生表';

insert into students(name,age,staus,gender) values ('小明',18,1,'男'),
                                                   ('小红',19,0,'女'),
                                                   ('小李',21,1,'女');
insert into students(name,age,gender) values ('小王',18,'男');
insert into students(name,age,gender) values (null,18,'男'); -- 报错
insert into students(name,age,gender) values ('小赵',17,'女');
insert into students(name,age,gender) values ('小刘',-1,'男'); -- 报错但是id还是+1
insert into students(name,age,gender) values ('小刘',22,'男'); -- id=7

select * from students;

外键约束

概念:外键用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性。

语法:

sql 复制代码
-- 添加外键
CREATE TABLE 表名(
      字段名 数据类型,
      [CONSTRAINT] [外键名称]FOREIGN KEY(外键字段名) REFERENCES 主表(主表列名)
);
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY(外键字段名) REFERENCES 主表(主表列名);

-- 删除外键
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;

示例:

sql 复制代码
update students set id=6 where id=7;-- 修正

create table class(
    id int primary key auto_increment comment '课程号',
    cname varchar(20) not null comment '课程名',
    tname varchar(20) not null comment '任课教师姓名'
)comment '选修课';

insert into class(cname, tname) values('高等数学','王X'),
                                      ('C++','李XX'),
                                      ('线性代数','张XX'),
                                      ('英语','吴XX'),
                                      ('物理','张X'),
                                      ('化学','游XX');


alter table students add column courseid int comment '选修课id';
update students set students.courseid= case id
    when 1 then 1
    when 2 then 2
    when 3 then 3
    when 4 then 4
    when 5 then 5
    when 6 then 6
end;

-- 关联students的courseid与class的id
alter table students add constraint fk_courseid foreign key (courseid) references class(id);

-- 删除外键
alter table students drop foreign key fk_courseid;

外键约束的删除和更新行为

其中NO ACTION/RESTRICT为默认行为。

语法:

sql 复制代码
ALTER TABLE 表名ADD CONSTRAINT 外键名称 FOREIGNKEY(外键字段) REFERENCES 主表名(主表字段名) ON UPDATE CASCADE ON DELETE CASCADE;
-- ON UPDATE CASCADE ON DELETE CASCADE:更新和删除时都CASCADE
相关推荐
倔强的石头_13 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横13 小时前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二13 小时前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐1 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
ClouGence2 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
云技纵横2 天前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql
无响应de神2 天前
三、用户与权限管理
数据库·mysql
摇滚侠2 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql