Oracle中的锁

本文介绍了数据库中的多种锁。TX锁在用户进行DML操作时加在行上;TM锁在DML操作时加在表上,防止DDL操作;DDL锁在DDL操作时加在表上,防止其他DDL操作;Parse锁针对存储过程;还有Manual锁和User - defined锁可由用户添加。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. TX锁:当用户对表进行DML操作时,会对操作的行加上TX锁,但是一个事务在数据字典中只能显示一个锁。在V$LOCK中,如果锁住的类型为TX,则其中的ID1及ID2经过处理,表示所在事务的transaction_id。
  2. TM锁:当用户对表进行DML操作时,在对行加上TX锁的同时,会对表加上TM共享锁,目的是防止有用户对表进行DDL操作。在V$LOCK中,如果锁的类型为TM,则其中的列ID1表示被锁住的对象的object_id。TM锁的数量可以由初始化参数DML_LOCKS决定。
  3. DDL锁:在用户对表进行DDL操作时,会对表加上DDL排他锁,从而防止其他用户对表进行DDL操作或加上TM共享锁。这意味着,在DDL操作完成之前,其他用户不能进行DDL操作或修改数据,但是可以进行查询。
  4. Parse 锁:主要针对存储过程,如果有用户正在执行存储过程,则会对其加上parse锁,从而防止有人对其进行修改。
  5. Manual锁以及User-defined锁:通过lock table或DBMS_LOCK包,由用户加上的锁。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/37724/viewspace-152527/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/37724/viewspace-152527/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值