数据库锁基本原理

简介: 在数据库系统的ACID特性中,隔离性是指数据库系统必须具有隔离并发运行的各个事务的能力,使它们不会相互影响。数据库采用锁来实现事务的隔离性。锁的基本原理如下:1、当一个事务访问某种数据库资源时,如果执行select语句必须先获得共享锁,如果执行insert、update、或delete语句,必须先获得独占锁,这些锁用于锁定被操作的资源。

在数据库系统的ACID特性中,隔离性是指数据库系统必须具有隔离并发运行的各个事务的能力,使它们不会相互影响。

数据库采用锁来实现事务的隔离性。锁的基本原理如下:

1、当一个事务访问某种数据库资源时,如果执行select语句必须先获得共享锁,如果执行insert、update、或delete语句,必须先获得独占锁,这些锁用于锁定被操作的资源。

2、当第二个事务也要访问相同的资源时,相应的语句也必须先获得相应的锁,此时就可以根据情况来决定第二个事务是等待锁,还是可以立即获得锁。

为了能够让用户根据实际应用的需求,在事务的隔离性与并发性之间做出合理的权衡,数据库系统提供了4种事务隔离级别供用户选择:

1)Serialiazble 串行化

2)Repeatable read 可重复读

3)Read commited 读已提交数据

4)Read Uncommited 读未提交的数据

数据库采用不同锁类型来实现4种隔离级别,具体的实现过程对用户是透明的。用户应该关心的是如何选择合适的隔离级别。

在4中隔离级别中,Seraliable的隔离级别最高,Read Uncommited级别最差。

对于多数应用程序,可以优先考虑把数据库系统的隔离级别设为Read Committed,它能够避免脏读,而且具有良好的并发性能。尽管它可能会导致不可重复读,虚读和第二类丢失更新等问题,在可能出现这类问题的个别场合,可以由应用程序采用悲观锁和乐观锁来控制。

 

基于元数据的 Spring 声明性事务(spring的隔离性事务) : 
Isolation 属性一共支持五种事务设置,具体介绍如下: 
   default:使用数据库设置的隔离级别 ( 默认 ) ,由 DBA 默认的设置来决定隔离级别。 
   read_uncommitted:会出现脏读、不可重复读、幻读 ( 隔离级别最低,并发性能高 ) 
   read_committed: 会出现不可重复读、幻读问题(锁定正在读取的行) 
   repeatable:会出幻读(锁定所读取的所有行) 
   serializable: 保证所有的情况不会发生(锁表) 

 

相关文章
|
1月前
|
SQL 存储 关系型数据库
数据库的行级锁与表锁?
表锁:存储引擎在SQL数据读写请求前对涉及的表加锁,分共享读锁和独占写锁,读锁阻塞写,写锁阻塞读写,易发锁冲突,并发性低。行级锁:InnoDB支持,通过索引加锁,提高并发性,但可能引起死锁,需注意索引使用,适用于避免不可重复读场景。
66 21
|
2月前
|
存储 缓存 网络安全
南大通用GBase 8s 数据库 RHAC集群基本原理和搭建步骤
南大通用GBase 8s 数据库 RHAC集群基本原理和搭建步骤
|
3月前
|
缓存 算法 关系型数据库
Mysql(3)—数据库相关概念及工作原理
数据库是一个以某种有组织的方式存储的数据集合。它通常包括一个或多个不同的主题领域或用途的数据表。
118 5
Mysql(3)—数据库相关概念及工作原理
|
2月前
|
存储 Java 关系型数据库
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践,包括连接创建、分配、复用和释放等操作,并通过电商应用实例展示了如何选择合适的连接池库(如HikariCP)和配置参数,实现高效、稳定的数据库连接管理。
79 2
|
3月前
|
监控 数据库 索引
避免锁等待超时对数据库性能的影响
【10月更文挑战第16天】避免锁等待超时对数据库性能的影响需要综合考虑多个方面,通过不断地优化和改进,来提高数据库的并发处理能力和稳定性。
50 1
|
3月前
|
SQL 关系型数据库 数据库
SQL数据库:核心原理与应用实践
随着信息技术的飞速发展,数据库管理系统已成为各类组织和企业中不可或缺的核心组件。在众多数据库管理系统中,SQL(结构化查询语言)数据库以其强大的数据管理能力和灵活性,广泛应用于各类业务场景。本文将深入探讨SQL数据库的基本原理、核心特性以及实际应用。一、SQL数据库概述SQL数据库是一种关系型数据库
139 5
|
3月前
|
存储 关系型数据库 MySQL
MySQL数据库锁:共享锁和独占锁
本文详细介绍了`InnoDB`存储引擎中的两种行级别锁:共享锁(S锁)与排他锁(X锁)。通过具体示例展示了这两种锁的工作机制及其在`InnoDB`与`MyISAM`引擎中的表现差异。文章还提供了锁的兼容性矩阵,帮助读者更好地理解锁之间的互斥关系。最后总结了两种锁的特点及适用场景。适合希望深入了解`MySQL`并发控制机制的读者阅读。
146 1
|
3月前
|
SQL 关系型数据库 MySQL
sql注入原理与实战(三)数据库操作
sql注入原理与实战(三)数据库操作
sql注入原理与实战(三)数据库操作
|
3月前
|
SQL 存储 Java
sql注入原理与实战(二)数据库原理
sql注入原理与实战(二)数据库原理
|
5月前
|
消息中间件 Kafka 数据库
深入理解Kafka的数据一致性原理及其与传统数据库的对比
【8月更文挑战第24天】在分布式系统中,确保数据一致性至关重要。传统数据库利用ACID原则保障事务完整性;相比之下,Kafka作为高性能消息队列,采用副本机制与日志结构确保数据一致性。通过同步所有副本上的数据、维护消息顺序以及支持生产者的幂等性操作,Kafka在不牺牲性能的前提下实现了高可用性和数据可靠性。这些特性使Kafka成为处理大规模数据流的理想工具。
121 6