数据库来一发(四)数据库的锁机制

2024-01-28 22:38
文章标签 数据库 机制 一发

本文主要是介绍数据库来一发(四)数据库的锁机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、锁的种类

数据库的锁分为:独占锁(或排他锁)、更新锁、共享锁、意向锁、计划锁。

1、独占锁(或排他锁)

独占锁锁定时,其他资源既不能写也不能读。

普通的update语句就会加独占锁,锁定n行。

2、共享锁

共享锁锁定时,其他资源可以读,但不能写。

普通的select语句加的是共享锁。

独占锁和共享锁是不能同时加的,或者说独占锁是不能跟其他的锁同时加的,所以在加独占锁前,一定会先等其他的锁都释放完,锁都是事务结束后才会释放。如果两个事务,都是先select后update同一段数据,那么就可能会出现互相等待对方释放共享锁,而形成死锁。

3、更新锁

为解决死锁加入了更新锁,加了更新锁的事务,会获得从共享锁升级到独占锁的资格。

4、意向锁、计划锁

不想了解。

二、锁的粒度

锁的粒度就是指锁的生效范围,就是说是行锁,页锁,还是表锁。

行锁,开销大、加锁慢,但由于粒度小,冲突概率低,并发度高。

页锁,介于其他两者之间。

表锁,开销小、加锁快、不会出现思索,但冲突概率高,并发度低。

三、乐观锁和悲观锁

1、悲观锁

悲观锁认为每次拿数据别人都会修改,因此都会在操作前上锁。

优缺点:悲观锁会让数据库产生额外开销,且增加死锁机会,降低了并行效率。但为数据一致性提供更强的保证。

应用场景:数据争用激烈,且并发冲突使用锁保护数据的成本低于回滚事务。

2、乐观锁

乐观锁认为取数据时冲突的概率不大,所以只是在更新的时候判断一下数据是否发生修改。

优缺点:不会产生死锁,相对于悲观锁效率更高,响应速度快。但一旦冲突就需要回滚,这是额外的成本。

应用场景:重试代价低,数据争用冲突频率低(减少重试几率)。

这篇关于数据库来一发(四)数据库的锁机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/655004

相关文章

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

Go语言并发之通知退出机制的实现

《Go语言并发之通知退出机制的实现》本文主要介绍了Go语言并发之通知退出机制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、通知退出机制1.1 进程/main函数退出1.2 通过channel退出1.3 通过cont

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.