锁(学习笔记)

行级锁定和表级锁定:

行级锁定:

当用户执行了,INSERT,UPDATE,DELETE及SELECT FOR UPDATE语句时,

ORACLE将隐式的实现记录的锁定,如果事务没有提交,回滚,就一直在锁定状态,一直到事务提交后,才会将数据锁释放

表级锁定:

表级锁定需要用户明确的使用LOCK TABLE语句手工锁定

语法

LOCK TABLE 表名称|视图名称,表名称|视图名.... IN 锁定模式 MODE[NOWAIT]

NOWAIT这是一个可选项,当视图锁定一张表时,如果发现已经被其他事务锁定时,不会等待

锁:共享锁和排它锁.

锁分以下几种:


ROW SHARE 行共享锁


在锁定期间允许其他事务并发对表进行各种操作,但不允许任何事务对同一张表进行独占操作(禁止排它锁)


ROW EXCLUSIVE 行排它锁


允许用户进行任何操作,与行共享锁不同的是它不能防止其它事务对同一张表进行手工锁或者独占操作


SHARE 共享锁


其它事务只能执行是查询操作,不能修改操作


SHARE ROW EXCLUSIVE 共享排它锁


能许任何用户进行查询操作,但不允许其它用户使用共享锁

共享排它锁的常见应用


EXCLUSIVE:排它锁


事务将以独占方式锁定表,其它用户允许查度,但不能修改也不能设置任何的锁

 

死锁:

将事务自动提交关闭

SET AUTOCOMMIT=OFF 取消自动处理,开启事务处理

悲观锁:查询到数据后使用FOR UPDATE 将数据锁定

第一个会话执行

SELECT * FROM myemp WHERE deptno=10 FOR UPDATE;

第2个会话也执行

SELECT * FROM myemp WHERE deptno=10 FOR UPDATE;

发现第2个会话,一直在等待,不执行

第一个会话执行COMMIT或者ROLLBACK后,会话2才可以执行

乐观锁:把所有锁定都延迟到即将执行更新之前

使用UPDATE 表名 set 字段  WHERE 字段1=查询出的状态,AND字段2=查询出的状态

在第一个SESSION上针对emp表使用共享锁

LOCK TABLE emp IN SHARE MODE NOWAIT

第二个SESSION中删除emp全部数据

DELETE FROM emp;

因是共享锁,第二个SESSION应该只能查度不能修改,所以一直在等待

解锁:

管理员登录

查看数据库中的锁定

SELECT session_id,oracle_username,process FROM v$locked_object;

可以发现死锁的SESSION_ID;

查询V$session数据字典

SELECT sid,serial#,username,lockwait,status FROM v$session where sid IN(SESSION_ID);

可以查询到Serial#

通过

ALTER SYSTEM KILL SESSION‘sid,serial#‘;

解除死锁

 

时间: 2024-08-06 20:04:48

锁(学习笔记)的相关文章

Linux程序设计学习笔记----多线程编程线程同步机制之互斥量(锁)与读写锁

互斥锁通信机制 基本原理 互斥锁以排他方式防止共享数据被并发访问,互斥锁是一个二元变量,状态为开(0)和关(1),将某个共享资源与某个互斥锁逻辑上绑定之后,对该资源的访问操作如下: (1)在访问该资源之前需要首先申请互斥锁,如果锁处于开状态,则申请得到锁并立即上锁(关),防止其他进程访问资源,如果锁处于关,则默认阻塞等待. (2)只有锁定该互斥锁的进程才能释放该互斥锁. 互斥量类型声明为pthread_mutex_t数据类型,在<bits/pthreadtypes.h>中有具体的定义. 互斥量

java/android 设计模式学习笔记(一)---单例模式

前段时间公司一些同事在讨论单例模式(我是最渣的一个,都插不上嘴 T__T ),这个模式使用的频率很高,也可能是很多人最熟悉的设计模式,当然单例模式也算是最简单的设计模式之一吧,简单归简单,但是在实际使用的时候也会有一些坑. PS:对技术感兴趣的同鞋加群544645972一起交流 设计模式总目录 java/android 设计模式学习笔记目录 特点 确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式的使用很广泛,比如:线程池(threadpool).缓存(cache).对

面向对象学习笔记

abstract:抽象类或方法的关键字注意事项:一个类中至少有一个抽象方法不允许有大括号主要意义就是规范方法,要求必须按照抽象中的方法来写继承抽象类的类,必须重载完全抽象类的方法抽象类是不能被实例化的,因为本身没有意义 extends 继承的关键字 类中常用的关键字:final 被定义的类不能被继承,该类的方法不能被继承,相当于一个锁的功能self self::静态成员,相当于类名称::静态成员,和this是有区别的,$this访问类中的内容必须实例化,而self是直接可以访问类中的内容的,多用

51CTO学习笔记--Linux运维故障排查思路与系统调优技巧视频课程(高俊峰)

51CTO学习笔记--Linux运维故障排查思路与系统调优技巧视频课程 第一课 Linux运维经验分享与思路 1.一般把主机名,写到hosts下    127.0.0.1    hostname,因为很多应用要解析到本地.oracle没有这个解析可能启动不了. 2.注释掉UUID以及MAC地址,需要绑定网卡的时候,这个可能会有影响. 3.磁盘满了无法启动,  var下木有空间,无法创创建PID等文件,导致文件无法启动,按e   进入single  然后b  重启进入单用户模式. 4.ssh登陆系

《Linux内核分析》第六周学习笔记

<Linux内核分析>第六周学习笔记 进程的描述和创建 郭垚 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 [学习视频时间:1小时 撰写博客时间:2小时] [学习内容:进程创建的过程.使用gdb跟踪分析内核处理函数sys_clone] 一.进程的描述 1.1 进程描述符task_struct数据结构(一) 1. 进程控制块PCB——task_struct 为了管理进程,内核

原型模式和Effective C++学习笔记

原型模式(Prototype):用原型实例制定创建对象的种类,并且听过拷贝这些原型创建新的对象. 浅复制:如果字段是值类型的,则对该字段执行逐位复制,如果字段是引用类型,则复制引用但不复制引用的对象:因此,原始对象及其副本引用同一对象. 深复制:把引用变量的对象指向复制过的新对象,而不是原有的被引用的对象. Effective C++: 1:在资源管理类中提供对原始资源的访问. (1),APIs 往往要求访问原始资源(raw resources),所以每一个 RAII class 应该提供一个"

黑马程序员_JAVA 基础加强学习笔记

一.面向对象 (一)继承  1.继承的好处: (1) 提高了代码的复用性. (2) 让类与类之间产生了关系,提供了另一个特征多态的前提. 注意: 子类中所有的构造函数都会默认访问父类中的空参数的构造函数,因为每一个子类构造内第一行都有默认的语句super();  如果父类中没有空参数的构造函数,那么子类的构造函数内,必须通过super语句指定要访问的父类中的构造函数. 如果子类构造函数中用this来指定调用子类自己的构造函数,那么被调用的构造函数也一样会访问父类中的构造函数. 2.final特点

程序员的自我修养 学习笔记(1)

本文源自在学习<程序员的自我修养>中的心得体会. 对于底层系统程序开发者来说,硬件平台可以抽象为三个主要部件,CPU.内存.I/O控制器. 早期的计算机没有复杂的图形功能,CPU和内存之间的频率差异不大,它们都是连接在同一个bus上面的.其他I/O设备,诸如显示设备.键盘.磁盘等速度比内存.CPU慢很多.为了IO设备与CPU.内存之间的协调通讯,一般每个IO设备商都有相应的IO控制器,早期的硬件结构图如下: 随着技术的进步,CPU的频率越来越高,内存跟不上CPU的速度,他们之间就需要一个转换机

Java NIO、NIO.2学习笔记

相关学习资料 http://www.molotang.com/articles/903.html http://www.ibm.com/developerworks/cn/education/java/j-nio/j-nio.html 目录 1. NIO.NIO.2简介 2. NIO中的关键技术 1. NIO.NIO.2简介 Java中的输入流.输出流都是阻塞式的输入.输出.不仅如此,传统的输入流.输出流都是通过字节的移动来处理的(即使是字符流,在底层也是通过字节流来进行处理的),也就是说,面向