文档章节

数据库x锁和s锁

wayhk
 wayhk
发布于 2015/05/02 22:17
字数 323
阅读 18
收藏 0

  共享锁(S锁):

  如果事务T对数据A加上共享锁后,则其他事务只能对A再加共享锁,不能加排他锁。获准共享锁的事务只能读数据,不能修改数据。

  排他锁(X锁):

  如果事务T对数据A加上排他锁后,则其他事务不能再对A加任任何类型的封锁。获准排他锁的事务既能读数据,又能修改数据。

  简要说明为什么会发生死锁?解决死锁的主要方法是什么?

  若干事务相互等待释放封锁,就陷入无限期等待状态,系统就进入死锁

  解决死锁的方法应从预防和解除的两个方面着手:

  (1)死锁的预防方法:①要求每一个事务必须一次封锁所要使用的全部数据(要么全成功,要么全不成功)②规定封锁数据的顺序,所有事务必须按这个顺序实行封锁。

  (2)允许死锁发生,然后解除它,如果发现死锁,则将其中一个代价较小的事物撤消,回滚这个事务,并释放此事务持有的封锁,使其他事务继续运行。

 


本文转载自:

共有 人打赏支持
wayhk
粉丝 1
博文 36
码字总数 17367
作品 0
海淀
程序员
数据库原理-事务基本概念

2018-1-9 by Atlas 数据库访问 read(X):把数据X,从磁盘的数据库中读到内存的缓冲区中。 write(X):把数据X,从内存的缓存区写回磁盘的数据库。 ACID性质 1、原子性(Atomicity) 一个事...

水天云黑白
01/09
0
0
事务并发的可能问题与其解决方案

一、多个事务并发时可能遇到的问题 Lost Update 更新丢失 a. 第一类更新丢失,回滚覆盖:撤消一个事务时,在该事务内的写操作要回滚,把其它已提交的事务写入的数据覆盖了。b. 第二类更新丢失...

傅易
2016/11/20
154
0
Oracle的TX锁(行级锁、事务锁)

问题:如何使用事务? 回答:一共有三步。 1、先开启事务。 •在Oracle中,事务是在上一次事务结束以后,数据“第一次”被修改时自动开启。 •在java中,设置连接为手动提交模式开始。代码:...

swearyd457
2013/10/10
0
0
数据库锁:乐观锁和悲观锁,共享锁和排它锁,行级锁和表级锁

一、悲观锁和乐观锁 我们经常在开发中遇到数据库并发处理时,处理不一致的问题。需要对程序做并发控制。 典型的并发时出现的冲突有两种: 1、丢失更新:一个事务的更新覆盖了其它事务的更新结...

vshcxl
2016/07/13
101
0
数据库中的锁

锁的概述一. 为什么要引入锁多个用户同时对数据库的并发操作时会带来以下数据不一致的问题:丢失更新A,B两个用户读同一数据并进行修改,其中一个用户的修改结果破坏了另一个修改的结果,比如订票...

东风125
2015/11/22
117
0

没有更多内容

加载失败,请刷新页面

加载更多

分布式锁的那点事

在多线程并发的情况下,要保证一个代码块在同一时间只能由一个线程访问,可以用锁来保证,比如java的synchronized语法以及ReentrantLock类等等。这样子可以保证JVM进程内的多个线程同步执行。...

无语年华
17分钟前
2
0
apahce启用http2

需要前置条件传送门 其实前置做完了,h2是很简单的事 1.apache启用http2_module 2.打开apche的配置文件,写上 Protocols h2 http/1.1 3.重启apache,打开浏览器看看吧...

gcudwork
33分钟前
1
0
redis-string

set key value 设置值 set命令有以下选项: ex senconds :为健设置秒级过期时间 px millisencondes :为健设置毫秒级过期时间 nx :健不存在时候,可以设置成功,用于添加 xx : 与nx相反,不...

拐美人
38分钟前
2
0
正弦 余弦 角度 用于画时钟

<html> <head> <title>时钟</title> </head> <style> #canvas{ background: #1977ca } </style>......

一箭落旄头
55分钟前
4
0
驰狼课堂

http://www.chilangedu.com/

求是科技
今天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部