mysql学习---事务

1、的业务操作,被事务管理,那么这些步骤要么全部成功,要么全部失败

2、操作

开启事务

sql 复制代码
mysql> start transaction;

回滚,任何一步执行失败则回滚,回滚到事务开启之前

sql 复制代码
mysql> rollback;

提交,mysql事务会默认提交dml语句,实现数据持久化更新,如果写了开启事务,则需要手动提交,否则会默认回滚

sql 复制代码
mysql> commit;

查询是否是默认提交

sql 复制代码
mysql> select @@autocommit;--1是默认提交,0是手动提交
mysql> set @@autocommit=0;--修改提交方式为手动提交

3、事务的四大特征

1)原子性:要么全部成功,要么全部失败

2)持久性:事务被提交或回滚后,数据库会持久化的保存数据

3)隔离性:多个事务之间相互独立

4)一致性:事务操作前后,数据总量不变

4、事务的隔离级别

多个事务操作同一批数据,可能会产生问题,设置不同的数据隔离级别,可以解决这些问题

存在问题

1)脏读:一个事务读取到另一个事务未提交的数据

2)不可重复读:在同一个事务中,两次读取的数据不一样,也成虚读

3)幻读:一个事务去操作数据表中所有的记录,另一个事务添加了一条数据,则第一个事务查询不到自己的修改

隔离级别

sql 复制代码
mysql> read uncommited;--读未提交,产生问题123
mysql> read commit;--读已提交,产生问题23
mysql> repeatable read;--可重复读,产生问题3,mysql默认的隔离级别
mysql> serializable;--串行化,会锁表,一个事务操作时,不允许另一个事务操作(查询操作也不允许)
mysql> SELECT @@transaction_isolation;--查看会话隔离级别
SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;--设置数据库隔离级别
相关推荐
ha20428941941 分钟前
Linux操作系统学习记录之----自定义协议(网络计算器)
linux·网络·学习
想唱rap6 分钟前
MYSQL在ubuntu下的安装
linux·数据库·mysql·ubuntu
振华说技能8 分钟前
SolidWorks学习大纲-从基础到全面精通,请看详情
学习
曦月逸霜8 分钟前
离散数学-学习笔记(持续更新中~)
笔记·学习·离散数学
im_AMBER20 分钟前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
java1234_小锋25 分钟前
MySQL中的乐观锁和悲观锁是什么?
mysql
Mr -老鬼40 分钟前
Rust与Go:从学习到实战的全方位对比
学习·golang·rust
laplace012341 分钟前
# 第四章|智能体经典范式构建 —— 学习笔记(详细版)
笔记·学习
程序猿零零漆42 分钟前
Spring之旅 - 记录学习 Spring 框架的过程和经验(十四)SpringMVC的请求处理
学习·spring·pandas
别了,李亚普诺夫44 分钟前
PCB设计大师篇笔记
笔记·嵌入式硬件·学习