DML锁又可以分为,行锁、表锁、死锁

行锁:当事务执行数据库插入、更新、删除操作时,该事务自动获得操作表中操作行的排它锁。

表级锁:当事务获得行锁后,此事务也将自动获得该行的表锁(共享锁),以防止其它事务进行DDL语句影响记录行的更新。事务也可以在进行过程中获得共享锁或排它锁,只有当事务显示使用LOCK TABLE语句显示的定义一个排它锁时,事务才会获得表上的排它锁,也可使用LOCK TABLE显示的定义一个表级的共享锁(LOCK TABLE具体用法请参考相关文档)。

死锁:当两个事务需要一组有冲突的锁,而不能将事务继续下去的话,就出现死锁。
如事务1在表A行记录#3中有一排它锁,并等待事务2在表A中记录#4中排它锁的释放,而事务2在表A记录行#4中有一排它锁,并等待事务1在表A中记录#3中排它锁的释放,事务1与事务2彼此等待,因此就造成了死锁。死锁一般是因拙劣的事务设计而产生。
死锁只能使用SQL下:alter system kill session “sid,serial#”;或者使用相关操作系统kill进程的命令,如UNIX下kill -9 sid,或者使用其它工具杀掉死锁进程。

DDL锁又可以分为:排它DDL锁、共享DDL锁、分析锁

排它DDL锁:创建、修改、删除一个数据库对象的DDL语句获得操作对象的 排它锁。如使用alter table语句时,为了维护数据的完成性、一致性、合法性,该事务获得一排它DDL锁。

共享DDL锁:需在数据库对象之间建立相互依赖关系的DDL语句通常需共享获得DDL锁。
如创建一个包,该包中的过程与函数引用了不同的数据库表,当编译此包时,该事务就获得了引用表的共享DDL锁。

分析锁:ORACLE使用共享池存储分析与优化过的SQL语句及PL/SQL程序,使运行相同语句的应用速度更快。一个在共享池中缓存的对象获得它所引用数据库对象的分析锁。分析锁是一种独特的DDL锁类型,ORACLE使用它追踪共享池对象及它所引用数据库对象之间的依赖关系。当一个事务修改或删除了共享池持有分析锁的数据库对象时,ORACLE使共享池中的对象作废,下次在引用这条SQL/PLSQL语句时,ORACLE重新分析编译此语句。

转载自:https://www.cnblogs.com/smellpawn/p/10799174.html

最新文章

  1. python 三元运算
  2. jquery 中post 、get的同步问题
  3. 如何生成可变表头的excel
  4. jsp学习一
  5. Man简单介绍
  6. SQL2008:在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。
  7. C# TextBox中只允许输入数字的方法
  8. JS 时间与时间戳的相互转换
  9. children
  10. C#集合之有序列表
  11. .NET 同步与异步 之 线程安全的集合 (十一)
  12. 公众号第三方平台开发 教程六 代公众号使用JS SDK说明
  13. Android学习之基础知识五—ListView控件(最常用和最难用的控件)
  14. 【iCore4 双核心板_FPGA】例程十六:基于双口RAM的ARM+FPGA数据存取实验
  15. 大数据学习笔记03-HDFS-HDFS组件介绍及Java访问HDFS集群
  16. Ubuntu server 运行.net core api 心得
  17. .NET基于Eleasticsearch搭建日志系统实战演练
  18. skb_pull skb_push skb_put
  19. HDU 6351 Beautiful Now(DFS)多校题解
  20. Java程序设计 第16周 课堂实践

热门文章

  1. Tomcat应用访问SSL或https失败的解决办法
  2. 1.关于OSI七层模型和两主机传输过程
  3. RabbitMQ的基本概念
  4. 去“BAT”这样面试,拿到offer的几率是80%
  5. c# 引用与对象举例
  6. Proxy ARP
  7. codeblocks glfw glew glm 配置
  8. 部署WCF Lib到IIS
  9. ASP.NET MVC 使用分部视图制作公共头部,尾部,并通过ViewBag传值
  10. centos6.5安装pip方法