ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

数据库事务与锁

2022-07-18 10:05:10  阅读:125  来源: 互联网

标签:事务 隔离 数据库 提交 排它 级别 读取


开启事务就自动加锁。
事务与锁是不同的。事务具有ACID(原子性、一致性、隔离性和持久性),锁是用于解决隔离性的一种机制。
事务的隔离级别通过锁的机制来实现。另外锁有不同的粒度,同时事务也是有不同的隔离级别的。
一个事务执行的任何过程中都可以获得锁,但是只有事务提交或回滚的时候才释放这些锁。

锁分类:
共享锁(读锁、S锁):加上共享锁后,其他用户不能获取排它锁,也就是说只能读不能写。例:事务里面做查询的查询操作就是加共享锁。
排它锁(写锁、X锁):加上排它锁后,其他用户不能获取任何锁,只有自己可以读、写。例:事务里做insert、update、delete就是加排它锁。
共享锁、排它锁属于悲观锁。
乐观锁:乐观锁的操作过程中没有任何锁的参与,乐观锁只是和悲观锁相对,严格的说乐观锁不能称之为锁,因为没有锁参与。

事务隔离级别(从上往下级别越严格):
1、ReadUncommitted(Read-Uncommitted即读取未提交):事务A修改数据,但是事务未提交;事务B中查到事务A中修改的数据。如果A事务发生回滚,就会导致B事务出现脏读情况。
2、ReadCommitted(Read-Committed即读取已提交):事务A修改数据,但是事务未提交;事务B中查到事务A中原始的数据。如果A事务提交后,就会导致B事务在不同时刻读取的值不一致。这就是不可重复读。
3、RepeatableRead(Repeatable-Read即可重复读取):读取数据的事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务。此隔离级别可有效防止不可重复读和脏读。
4、Serializable(可串行化):提供严格的事务隔离。它要求事务序列化执行,事务只能一个接着一个地执行,不能并发执行。此隔离级别可有效防止脏读、不可重复读和幻读。

标签:事务,隔离,数据库,提交,排它,级别,读取
来源: https://www.cnblogs.com/miskey/p/16489354.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有