当前位置: 首页 > news >正文

mysql学习---事务

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

mysql> start transaction;

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

mysql> rollback;

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

mysql> commit;

查询是否是默认提交

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

3、事务的四大特征
1)原子性:要么全部成功,要么全部失败
2)持久性:事务被提交或回滚后,数据库会持久化的保存数据
3)隔离性:多个事务之间相互独立
4)一致性:事务操作前后,数据总量不变
4、事务的隔离级别
多个事务操作同一批数据,可能会产生问题,设置不同的数据隔离级别,可以解决这些问题
存在问题
1)脏读:一个事务读取到另一个事务未提交的数据
2)不可重复读:在同一个事务中,两次读取的数据不一样,也成虚读
3)幻读:一个事务去操作数据表中所有的记录,另一个事务添加了一条数据,则第一个事务查询不到自己的修改
隔离级别

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;--设置数据库隔离级别
http://www.dtcms.com/a/449223.html

相关文章:

  • 网站建设情况通报公司注册资金需要多少
  • 【C++实战(75)】筑牢安全防线,攻克漏洞难题
  • 西安网站托管排名网站建设技术支持有什么
  • 【OTA升级】英飞凌TC397实现刷写失败回滚(A/B分区)
  • 揭开 C++ vector 底层面纱:从三指针模型到手写完整实现
  • 【嵌入式】【GIT】终端中文乱码修复
  • LabVIEW 并行 For 循环应用与对比
  • 广东石油化工建设集团网站设计工作室发展前景
  • (五)Vue.js 高级语法②
  • Ansible核心架构深度剖析:从源码看IT自动化的“简单“哲学
  • 深圳建站公司价格内网访问wordpress很慢
  • 网站制作咨网站备案账号密码
  • 继续补js
  • set authentication password cipher 概念及题目
  • 【高级版】沃德政务招商系统源码+uniapp小程序
  • 什么时候需要close()释放资源
  • 小迪安全v2023学习笔记(九十七天)—— 云原生篇KubernetesK8s安全APIKubelet未授权访问容器执行
  • 网站建设itcask单页网站seo
  • 设计模式学习[20]---桥接模式
  • 【第三次全国土壤普查】-土壤类型图报告编制及评分标准
  • python爬虫(一) ---- 静态html数据抓取
  • 《剑指Offer:单链表操作入门——从“头删”开始破解面试》
  • 网站备案号怎么查询做设计私活的网站
  • 微信小程序入门学习教程,从入门到精通,WXS语法详解(10)
  • 深圳做网站公司哪家好在线绘画网站
  • CodeX CLI安装+MCP适配与VSCode部署(Win)
  • 手写MyBatis第95弹:异常断点精准捕获MyBatis深层BUG
  • 网站的结构是什么样的鹰潭律师网站建设
  • Rust多线程详解
  • tcp 服务器的设计思路