Oracle数据库中哪些情况会导致表被锁定?
在Oracle数据库中,表被锁定是一个比较常见的情况,一般是由于用户进行数据操作时导致的。常见的表被锁定的情况包括行级锁定、事务级锁定,以及DDL操作等。下面将具体介绍这些情况并给出相应的代码示例。
- 行级锁定:
当用户在一个事务中对表进行更新操作时,数据库会对相应的数据行进行锁定,防止其他事务同时修改该数据。如果事务没有提交或回滚,那么其他事务将无法修改该数据,从而导致表被锁定。以下是一个简单的行级锁定示例:
-- 事务1
BEGIN
UPDATE employees
SET salary = salary * 1.1
WHERE department_id = 10
FOR UPDATE;
COMMIT;
END;
-- 事务2
BEGIN
UPDATE employees
SET salary = salary * 1.2
WHERE employee_id = 100;
-- 此时因为employee_id=100被事务1锁定,导致事务2无法执行
END;




