news 2026/4/15 6:06:06

MySQL基础篇——约束和事务

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL基础篇——约束和事务

事务与隔离级别比较常考

1、MySQL约束

约束作用于表中字段,在创建/修改表时使用

非空约束,唯一约束,主键约束,默认约束,检查约束,外键约束

create table user( id int primary key auto_increment comment '主键', --主键且自动增长 name varchar(10) not null unique comment '姓名', --非空且唯一 age int check (age>0 and age<=120) comment '年龄', --检查约束0-120岁范围 status char(1) default '1' comment '状态', --默认值为1 gender char(1) comment '性别' )comment '用户表'; --插入数据 insert into user(name, age, status, gender) values('tom1', 19, '1', '男'),('tom2', 22, '0', '男');

外键约束(两张表之间数据一致性)

父表的主键id——关联——子表的外键字段(如dept_id)

--已有表添加外键 alter table 表名 add constraint 外键名称 foreign key (外键字段名) references 主表(主表列名); alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id); --将emp表dept_id与dept表的id字段关联 --新增表添加外键 create table student_course( id int primary key auto_increment comment '主键', studentid int not null comment '学生ID', courseid int not null comment '课程ID', constraint fk_courseid foreign key (courseid) references course(id), constraint fk_studentid foreign key (studentid) references student(id) )comment '学生课程中间表'; --删除外键 alter table 表名 drop foreign key fk_emp_dept_id; --外键删除更新行为 no action/restrict(默认值 不允许更改)、cascade(对应修改)、set null alter table 表名 add constraint 外键名称 foreign key (外键字段名) references 主表(主表列名)on update cascade on delete cascade;

2、多表查询

多表关系:多对一(添加外键),多对多(新增中间表添加外键),一对一(添加外键且唯一约束)

--自连接 select a.name, b.name from emp a left join emp b on a.managerid=b.id; -- 必须有别名 --联合查询union、union all(上下合并查询结果) select * from a union [all] select * from b; --union 合并去重,union all只合并,字段列数必须相同 --子查询 select * from emp where (salary, managerid)= (select salary, managerid from emp where name ='tom') --一行多列数据

3、事务操作

事务是一组操作的集合,全部成功/全部失败

--MySQL默认事务自动提交 select @@autocommit; --查看事务提交方式,1自动提交,0手动提交 set @@autocommit=0; --设置事务提交方式 commit; --提交事务 rollback; --回滚事务(回到初始状态) start transaction 或 begin; --开启事务 create table account( id int primary key auto_increment comment '主键ID', name varchar(10) comment '姓名', money int comment '余额' )comment '账户表'; insert into account(name,money) values ('a',2000),('b',2000); --转账操作(手动提交) select @@autocommit; set @@autocommit=0; --1、查询a用户余额 select * from account where name ='a'; --2、将a账户余额减去1000 update account set money = money - 1000 where name ='a'; --3、将b账户余额加上1000 update account set money = money + 1000 where name ='b'; commit; rollback; --如果执行出错; --若为自动提交的事务(比较常用) start transaction; ... commit; rollback; --如果执行出错;

事务四大特性 ACID

原子性A:事务是不可分割的最小操作单元,要么全部成功,要么全部失败;

一致性C:事务完成时,必须使所有数据都保持一致状态;

隔离性I:数据库系统提供的隔离机制,保证不同事务不受外部并发操作影响的独立环境下运行;

持久性D:事务一旦提交,它对数据库中数据的改变是永久的,哪怕数据库发生故障;

并发事务问题

1、脏读:一个事务读到另一个事务还没有提交的数据;

2、不可重复读:一个事务先后读取同一条记录,但两次读取的数据不同;Update / Delete

3、幻读:一个事务按照条件查询数据时,没有对应的数据行,但是插入数据时又发生这行数据已经存在;Insert

事务的隔离级别

select @@transaction_isolation; --查看事务隔离级别 set [session|global] transaction isolation level read uncommitted; --设置事务隔离级别 --session当前会话,global全局

1、read uncommitted:三种问题都会出现;

2、read committed:有不可重复读和幻读问题;

3、repeatable read(MySQL默认):有幻读问题;

4、serializable:串行化均无问题,隔离级别最高,数据最安全,性能最差;

这是理论情况,实际应用有一些变化,在锁的部分会讲解。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/9 0:02:27

AI写论文靠谱吗?

当“AI写论文”这个概念从科幻走向现实&#xff0c;并迅速成为圈内热议话题时&#xff0c;科研人员内心最直接、最现实的疑问往往是&#xff1a;这玩意儿到底靠不谱&#xff1f;我们既期待它能成为解放生产力的利器&#xff0c;又担忧它可能带来的学术不端风险、内容空洞或逻辑…

作者头像 李华
网站建设 2026/4/13 18:03:52

手心输入法:纯净轻量无广的必备输入法

一、产品背景&#xff1a;针对行业痛点的 “反冗余” 突围 1. 行业痛点催生需求 第三方输入法市场长期存在三大核心痛点&#xff0c;成为用户核心抱怨点&#xff1a; 广告骚扰泛滥&#xff1a;头部产品&#xff08;如搜狗&#xff09;通过弹窗广告、皮肤推荐、第三方推广变现…

作者头像 李华
网站建设 2026/4/11 16:56:47

【C++】--- 类型转换

Welcome to 9ilks Code World (๑•́ ₃ •̀๑) 个人主页: 9ilk (๑•́ ₃ •̀๑) 文章专栏&#xff1a; C 本篇博客主要是对C/C中类型转换的梳理总结。 内置类型转换 在C语言中&#xff0c;如果赋值运算符左右两侧类型不同&#xff0c;或者形参与实参类型不匹…

作者头像 李华
网站建设 2026/4/14 11:14:14

Wan2.2-T2V-A14B与PixVerse、Kling等国产模型横向评测

Wan2.2-T2V-A14B与PixVerse、Kling等国产模型横向评测 在短视频日活突破8亿、AIGC内容渗透率加速攀升的今天&#xff0c;一个现实正变得愈发清晰&#xff1a;人工拍摄不再是视频生产的唯一路径。从抖音上的AI动画短剧&#xff0c;到品牌方批量生成的千人千面广告&#xff0c;文…

作者头像 李华
网站建设 2026/4/2 13:31:48

一天认识一个STL库函数——size()

一、什么是size()函数&#xff1f;在C的STL&#xff08;Standard Template Library&#xff09;中&#xff0c;size()是一个极其常用的成员函数&#xff0c;用于返回容器中当前元素的数量。无论你使用的是vector、list、set、map还是其他STL容器&#xff0c;size()都能帮你快速…

作者头像 李华
网站建设 2026/4/11 1:45:51

智能Agent与Docker容器编排实战(高可用架构设计稀缺方案)

第一章&#xff1a;智能Agent的Docker容器编排策略在构建分布式智能Agent系统时&#xff0c;Docker容器化技术为环境一致性、快速部署与资源隔离提供了坚实基础。然而&#xff0c;随着Agent数量增长和交互复杂度上升&#xff0c;单一容器管理已无法满足需求&#xff0c;必须引入…

作者头像 李华