- TX锁:当用户对表进行DML操作时,会对操作的行加上TX锁,但是一个事务在数据字典中只能显示一个锁。在V$LOCK中,如果锁住的类型为TX,则其中的ID1及ID2经过处理,表示所在事务的transaction_id。
- TM锁:当用户对表进行DML操作时,在对行加上TX锁的同时,会对表加上TM共享锁,目的是防止有用户对表进行DDL操作。在V$LOCK中,如果锁的类型为TM,则其中的列ID1表示被锁住的对象的object_id。TM锁的数量可以由初始化参数DML_LOCKS决定。
- DDL锁:在用户对表进行DDL操作时,会对表加上DDL排他锁,从而防止其他用户对表进行DDL操作或加上TM共享锁。这意味着,在DDL操作完成之前,其他用户不能进行DDL操作或修改数据,但是可以进行查询。
- Parse 锁:主要针对存储过程,如果有用户正在执行存储过程,则会对其加上parse锁,从而防止有人对其进行修改。
- Manual锁以及User-defined锁:通过lock table或DBMS_LOCK包,由用户加上的锁。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/37724/viewspace-152527/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/37724/viewspace-152527/