【终身难忘的记忆法】事务隔离级别
前几天看spring3.x的时候,看到了事务隔离级别那,提到这就要提到五种常见的事务并发问题,就是大家耳熟能详的脏读、幻读、不可重复读、第一类更新丢失、第二类更新丢失。那么今天我就主要来讲最常用的前三类问题,当然,是用最易懂的方式。 首先,什么是脏
前几天看spring3.x的时候,看到了事务隔离级别那,提到这就要提到五种常见的事务并发问题,就是大家耳熟能详的脏读、幻读、不可重复读、第一类更新丢失、第二类更新丢失。那么今天我就主要来讲最常用的前三类问题,当然,是用最易懂的方式。
首先,什么是脏读?
学术解释:脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。
我的解释:你正在做菜,把切好的菜放在一边准备下锅,这时候,妻子告诉你开饭了,然后端着你这堆还没下锅的菜就放到了餐桌上。
什么是不可重复读?
学术解释:不可重复读:是指在一个事务内,多次读同一数据。在这个事务还没有结束时,另外一个事务也访问该同一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的的数据可能是不一样的。这样在一个事务内两次读到的数据是不一样的,因此称为是不可重复读。
我的解释:当你是一个乐队的指挥,当第一乐章的小提琴独奏开始时,你觉得他非常美妙; 可到了第二乐章小提琴独奏的时候,你发现他消失了,观众告诉你他中途上厕所去了,还没回来。
什么是幻读?
学术解释:是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,以后就会发生操作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样。
我的解释:我同“不可重复读”用同一个场景,当你在演奏第一乐章的时候,你觉得音乐非常美妙,但到了第二乐章的时候,你突然感觉音乐出现了不和谐的声音,然后你发现,乐队突然多了一个鼓手。
不可重复读和幻读的区别?
不可重复读是指你第一次注意乐队里的一个人,第二次看到他时,出现了变化。
幻读是指,你第一次注意的由很多人组成的乐队,当第一次看到这支乐队时,乐队多了一个人。
不可重复读针对的是个人,一条数据。
幻读针对的是集合、多条数据。
最后提一下事务的四个隔离级别,要注意自上而下的顺序,并发速度可是递减的哦。
MySQL5 默认的事务隔离级别为:REPEATABLE-READ
查看 MySQL5 的事务隔离级别:select @@select @@tx_isolation;
修改 MySQL5 的事务隔离级别:set transaction isolation level read committed;

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Lockwaittimeoutexceeded;tryrestartingtransaction-如何解决MySQL报错:事务等待超时在使用MySQL数据库时,有时可能会遇到一个常见的错误:Lockwaittimeoutexceeded;tryrestartingtransaction,该错误表示事务等待超时。这个错误通常发生在并

1.PDO简介PDO是PHP的一个扩展库,它提供了一个面向对象的方式来操作数据库。PDO支持多种数据库,包括Mysql、postgresql、oracle、SQLServer等。PDO使开发人员能够使用统一的api来操作不同的数据库,这使得开发人员可以在不同的数据库之间轻松切换。2.PDO连接数据库要使用PDO连接数据库,首先需要创建一个PDO对象。PDO对象的构造函数接收三个参数:数据库类型、主机名、数据库用户名和密码。例如,以下代码创建了一个连接到mysql数据库的对象:$dsn="mysq

MySQL事务处理:自动提交与手动提交的区别在MySQL数据库中,事务是一组SQL语句的集合,要么全部执行成功,要么全部执行失败,保证了数据的一致性和完整性。在MySQL中,事务可以分为自动提交和手动提交,其区别在于事务提交的时机以及对事务的控制范围。下面将详细介绍自动提交和手动提交的区别,并给出具体的代码示例来说明。一、自动提交在MySQL中,如果没有显示

win10病毒隔离的文件一般都会固定的存放位置,很多用户想打开隔离文件恢复自己的文件,但是不知道在哪里存着,其实通常在c盘安全软件的隔离文件夹里就能找到。win10病毒隔离的文件在哪里答:在C:\ProgramData\Microsoft\WindowsDefender\Quarantine文件夹里,我们可以打开此电脑,直接将该文件路径复制粘贴到上方路径栏里找到他。win10病毒隔离文件夹介绍:1、在win10中“Quarantine”文件通常需要一定权限打开,建议使用管理员身份打开该文件。2、

事务确保数据库数据完整性,包括原子性、一致性、隔离性和持久性。JDBC使用Connection接口提供事务控制(setAutoCommit、commit、rollback)。并发控制机制协调并发操作,使用锁或乐观/悲观并发控制来实现事务隔离性,以防止数据不一致。

PHP数据对象(PDO)扩展提供了与数据库服务器高效且面向对象的交互。其高级查询和更新功能使开发人员能够执行复杂的数据库操作,从而提高性能和代码可维护性。本文将深入探讨PDO的高级查询和更新功能,指导您掌握其强大功能。高级查询:使用占位符和绑定参数占位符和绑定参数是提高查询性能和安全性的重要工具。占位符使用问号(?)表示查询中可替换的参数,而绑定参数则允许指定每个参数的数据类型和值。通过使用这些方法,您可以避免sql注入攻击并提高性能,因为数据库引擎可以提前优化查询。//使用占位符$stmt=$

如何使用Java9中的模块系统来分离和隔离代码随着软件规模不断扩大,代码的复杂度也在不断增加。为了更好地组织和管理代码,Java9引入了模块系统。模块系统的出现解决了传统的包依赖的问题,使得代码的分离和隔离更加容易和灵活。本文将介绍如何使用Java9中的模块系统来实现代码的分离和隔离。一、模块的定义在Java9中,我们可以使用module关键字来定义

MySQL事务的原理及应用场景在数据库系统中,事务是一组SQL操作的集合,这些操作要么全部成功执行,要么全部失败回滚。MySQL作为一种常用的关系型数据库管理系统,支持事务的特性,能够确保数据库中的数据在一致性、隔离性、持久性和原子性方面得到保证。本文将从MySQL事务的基本原理入手,介绍其应用场景,并提供具体的代码示例供读者参考。MySQL事务的原理:My
