news 2026/6/22 23:57:40

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/6/22 13:52:35

【VSCode量子编程环境搭建指南】:手把手教你5步配置Qiskit开发环境

第一章&#xff1a;VSCode量子编程环境搭建概述 在当前量子计算快速发展的背景下&#xff0c;开发者需要一个高效、灵活且可扩展的开发环境来编写和调试量子程序。Visual Studio Code&#xff08;VSCode&#xff09;凭借其强大的插件生态和轻量级架构&#xff0c;成为构建量子编…

作者头像 李华
网站建设 2026/6/22 18:14:28

Flutter深度解析:从原理到实战的全栈开发指南

Flutter深度解析&#xff1a;从原理到实战的全栈开发指南引言&#xff1a;跨平台开发的革命性突破在移动开发领域&#xff0c;React Native、UniApp等方案曾占据主导地位&#xff0c;但Flutter凭借其独特的自绘引擎和声明式UI范式&#xff0c;已成为构建高性能跨平台应用的首选…

作者头像 李华
网站建设 2026/6/23 5:53:55

Wan2.2-T2V-A14B能否生成适用于VR心理暴露疗法的创伤情境

Wan2.2-T2V-A14B能否生成适用于VR心理暴露疗法的创伤情境 在一场深夜的心理咨询中&#xff0c;一位退伍军人低声描述着那段挥之不去的记忆&#xff1a;雨夜、泥泞的山路、突然响起的爆炸声。传统治疗依赖他“想象”那个场景&#xff0c;但语言的边界往往限制了情绪的真实唤醒—…

作者头像 李华
网站建设 2026/6/23 5:28:36

数据结构-栈(核心代码)

顺式结构#define _CRT_SECURE_NO_WARNINGS 1//栈的顺式结构#include<stdio.h> #define MAXSIZE 100 typedef int Elemtype; //定义栈 typedef struct stack {Elemtype data[MAXSIZE];int top; }Stack; //初始化栈 void initstack(Stack* S) {S->top -1; } //判断栈是…

作者头像 李华