Oracle Lock 概述
按锁的机制分类
排他锁( X ):如果事务T对对象A加上排他锁,则只允许T对A对象读取和修改,其他事务不能对A增加任何锁,直到T释放加载A上的排他锁
共享锁( S ):如果事务T对表A加上共享锁,则事务T可以读该表,但是不能修改该表数据。其他事务也只能对该对象加上共享锁,但是不能加上排他锁。这就保证了其他事务可以读A表数据,但是不能修改A表数据(这就不会影响到读该表的事务了,有利于并发操作)。
按操作行为分类
DML Locks 保证并发情况下的数据完整性
DDL Locks 用于保护数据库对象的结构
System Locks 保护数据库的内部结构
DML Locks:
Row Locks (TX) 称为行级锁。当事务执行 DML 语句(INSERT, UPDATE, DELETE, and SELECT with the FOR UPDATE clause)时会申请TX 类型的锁,TX 的机制是排他锁。
Table Locks (TM) 称为表级锁。当Oracle执行 DML 语句时,系统自动在所要操作的表上申请TM类型的锁。
TM锁类型表细分:
| SQL Statement | Mode of Table Lock | Lock Modes Permitted? | ||||
| RS | RX | S | SRX | X | ||
| SELECT...FROM table... | none | Y | Y | Y | Y | Y | 
| INSERT INTO table ... | RX | Y | Y | N | N | N | 
| UPDATE table ... | RX | Y* | Y* | N | N | N | 
| DELETE FROM table ... | RX | Y* | Y* | N | N | N | 
| SELECT ... FROM table FOR UPDATE OF ... | RS | Y* | Y* | Y* | Y* | N | 
| LOCK TABLE table IN ROW SHARE MODE | RS | Y | Y | Y | Y | N | 
| LOCK TABLE table IN ROW EXCLUSIVE MODE | RX | Y | Y | N | N | N | 
| LOCK TABLE table IN SHARE MODE | S | Y | N | Y | N | N | 
| LOCK TABLE table IN SHARE ROW EXCLUSIVE MODE | SRX | Y | N | N | N | N | 
| LOCK TABLE table IN EXCLUSIVE MODE | X | N | N | N | N | N | 
 RS: row share
   RX: row exclusive
   S: share
   SRX: share row exclusive
   X: exclusive
注:Y的含义是完全不阻塞其它事务对相应锁的申请;Y*的含义是不阻塞其它事务对相应锁的申请(同表不同行),但对同一行数据申请相应的琐时则会发生等待。
DDL Locks:
排他DDL锁(Exclusive DDL lock):阻塞其他会话得到该对象的DDL锁或DML锁。在DDL操作期间你可以查询一个表,但是无法以任何方式修改这个表。
共享DDL锁(Share DDL lock):保护所引用对象的结构,使其结构不会被其他会话修改。
相关视图
- V$LOCK
- V$LOCKED_OBJECT
Oracle Lock 概述的更多相关文章
- [Oracle] Lock&Latch梳理
		Oracle lock&latch 1. 概述 4种锁机制 lock latch pin mutex 保证资源在并发访问和修改时不被破坏 锁类型 行为 持有时间 级别 保护类型 lock 队列 ... 
- 1.Oracle数据库概述
		Oracle数据库概述 1.1Oracle结构图 1.1如何访问数据库 a.本机直接通过sock(套接字)方式访问 IPC UDP协议 ,不需要网络 b.通过tcp建立连接到oracle服务器 1. ... 
- [整理]Oracle LOCK 机制
		数据库是一个多用户使用的共享资源.当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况.若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性.锁机制用于管理对 ... 
- ORACLE触发器概述之【语句触发器】【weber出品】
		一.触发器概述 与表,视图,模式,或者数据库相关的PL/SQL过程,当触发条件被触发时,自动执行 分类: 1.语句触发器 2.行触发器 二.语句触发器 1. 什么是语句触发器 语句触发器,是指当执行D ... 
- Oracle Lock(Enqueues)
		转载:http://www.cnblogs.com/Richardzhu/articles/2796540.html 数据库是一个多用户使用的共享资源.当多个用户并发地存取数据时,在数据库中就会产生多 ... 
- ORACLE基础之oracle锁(oracle lock mode)详解
		ORACLE里锁有以下几种模式: 0:none 1:null 空 2:Row-S 行共享(RS):共享表锁,sub share 3:Row-X 行独占(RX):用于行的修改,sub exclusiv ... 
- oracle lock
		数据库锁介绍: https://www.cnblogs.com/springsnow/p/9990295.html#_label2_0 总结1:查询oracle锁定的表: 1.锁相关表 SELECT ... 
- Oracle基础概述
		本部分主要参考”风哥“的Oracle入门视频. 一.体系结构概述 1.物理结构(文件结构) Oracle有四种文件:控制文件.数据文件.日志文件.参数文件 其中日志文件分为两类:联机日志文件.归档日志 ... 
- Oracle数据库概述
		Oracle是一种RDBMS(Relational Database Management System 关系型数据库管理系统),是Oracle公司的核心产品. 2009年4月,Oracle并购了Su ... 
随机推荐
- Ping pong
			Ping pong Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ... 
- jq层次选择器
			二. 层次选择器 1. parent > child(直系子元素) $(document).ready(function () { // 选取div下的第一代span元素,将字体颜色设为红色 $ ... 
- Python Virtualenv 虚拟环境
			在python2和python3共存的机器上做开发,要想互不干扰,虚拟环境很重要. Debian7 默认是python2.7.3,装好python3.4.1后怎么建立虚拟环境呢? $ pyvenv m ... 
- Leetcode 190. Reverse Bits(反转比特数)
			Reverse bits of a given 32 bits unsigned integer. For example, given input 43261596 (represented in ... 
- Nginx - HTTP Configuration, Module Variables
			The HTTP Core module introduces a large set of variables that you can use within the value of direct ... 
- (译)如何在ASP.NET中安全使用ViewState
			原文:http://www.codeproject.com/Articles/150688/How-to-make-ViewState-secure-in-ASP-NET 介绍 ASP.NET中的Vi ... 
- 会话—cookie
			什么是会话? 会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话. 会话过程中要解决的一些问题? 每个用户在使 ... 
- Javascript之简单按钮搜索功能
			学习JavaScript我觉得真实的感觉就是可以任意设计,“没有做不到只有想不到!”即使简单,但是任何东西的复杂都是从简单.基础开始的!这是我自己做的一个超简单的"搜索引擎"按钮, ... 
- Java之绘制二次曲线
			前面已经介绍过绘制方法.这里不再赘述. 画一下草图来看看:灰色表示X值,红色表示Y值. 在这里要值得注意的是:当我们把它们的坐标在纸上画出来时,就会觉得“有问题”了,你看A(60,20,120,100 ... 
- Cocos中的观察者设计模式与通知机制
			观察者(Observer)模式也叫发布/订阅(Publish/Subscribe)模式,是 MVC( 模型-视图-控制器)模式的重要组成部分.天气一直是英国人喜欢讨论的话题,而最近几年天气的变化也成为 ... 
