数据库开发——并发控制(第十一章)

文章目录

学习目标:重点为并发控制的基本概念及几个基本协议

前言

数据库管理系统必须提供并发控制机制,保证事务的隔离性和一致性

并发执行例题

一、封锁

排他锁称为写锁,共享锁称为读锁。

只有读锁+读锁是共享的,其他的一切组合都是互斥的。

二、封锁协议


注意

1、三级协议的主要区别:什么操作需要申请封锁以及何时释放锁(即持锁时间)

2、不同的封锁协议使事务达到的一致性级别不同:封锁协议级别越高,一致性程度越高

三、可串行调度

1、可串行化调度

多个事务的并发执行是正确的,当且仅当其结果与按某一次序串行地执行这些事务时的结果相同。

一个调度Sc在保证冲突操作的次序不变的情况下,通过交换两个事务不冲突操作的次序得到另一个调度Sc',如果Sc'是串行的,称调度Sc是冲突可串行化的调度

2、如何判断可串行调度???

注意点:

1、冲突操作是指不同的事务对同一数据的读写操作和写写操作。

2、调换,一个将事务一样的放在一起,一个一个比对,若不冲突,则可以调换,一直到所有相同的事务放在一起。

四、总结

1、封锁粒度与系统的并发度和并发控制的开销密切相关

封锁的粒度越大,数据库所能够封锁的数据单元就越少,并发度就越小,系统开销也越小;

封锁的粒度越小,并发度较高,但系统开销也就越大。

相关推荐
Irissgwe2 分钟前
Mysql数据库基础
数据库·c++·mysql·mysql数据库基础
qq_334903156 分钟前
用Python实现自动化的Web测试(Selenium)
jvm·数据库·python
一只努力的微服务16 分钟前
【Calcite 系列】深入理解 Calcite 的 AggregateFilterTransposeRule
大数据·数据库·calcite·优化规则
m0_5180194819 分钟前
使用Python操作文件和目录(os, pathlib, shutil)
jvm·数据库·python
轩情吖19 分钟前
MySQL Connect
数据库·mysql·adb·select·连接·远程访问数据库
lifewange22 分钟前
SQL中的聚合函数有哪些
android·数据库·sql
阿贵---25 分钟前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
稻草猫.25 分钟前
MyBatis-Plus高效开发全攻略
java·数据库·后端·spring·java-ee·mybatis·mybatis-plus
人道领域37 分钟前
Day | 09 【苍穹外卖:订单售后业务】
java·数据库·后端
minji...40 分钟前
Linux 进程间通信(一)进程间通信与匿名管道
linux·运维·服务器·数据结构·数据库·c++