当前位置:   article > 正文

Oracle多用户同时修改同一记录,怎样保证该客户记录_oracle并发修改同一条数据

oracle并发修改同一条数据
首先你要了解什么叫做 “事务 transcation ” :一个事务包含一个或多个DML语句,是逻辑管理的工作单元(原子单元)。  
注意:其中Commit, Rollback是显示的提交事务,而DDL语句是隐式的提交事务的。DDL语句的操作是没有办法回滚的。

当用户对数据进行修改时(DML操作),oracle会给数据分配两个 锁 ,一个是行排他锁 另一个是表共享锁
行排他锁:如果A用户对某个表的某一行进行修改时,会把该行分配一个”行排他锁“

这样B用户就只能查看 不能修改了。但是B用户看到的数据确实老数据 , 那是因为A用户还没有结束该事务,换句话说A用户拿到了修改该行的所有权,但是怎么修改,修改之后会不会反悔 这些都是在A 提交该事务之前的 仅属于他个人的事情
而为了保证所有用户所看到数据的一致性, 在A用户 提交事务之前 大家看到的数据都是 老数据

举个例子:
1. 最开始 谁也没要修改的时候,数据是这样的:
SQL> select empno , ename , sal from emp where empno= 7900;
EMPNO ENAME SAL
---------- ---------- ----------
7900 JAMES 950

2. A用户进行修改了,她就拿到了 这行的锁:
SQL> update emp set sal=6000 where empno=7900;
1 row updated.

SQL> select empno , ename , sal from emp where empno= 7900;
EMPNO ENAME SAL
---------- ---------- ----------
7900 JAMES 6000
现在只有A用户能够查看到,修改后的数据。

3. B用户进行查看:
SQL> select empno , ename , sal from emp where empno= 7900;
EMPNO ENAME SAL
---------- ---------- ----------
7900 JAMES 950

4. B用户进行修改:
SQL> update emp set sal=6000 where empno=7900;
......... 没有任何动静,因为该会话在等待A用户的提交。 过了十分钟后,A用户提交了 那么B立刻就抢到了这把锁。

”如果多个用户同时修改同一客户记录,而且先后提交修改,Oracle 怎样保证该客户记录“ 就像按抢答器一样,就看是谁先得到这把”锁“

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/387273
推荐阅读
相关标签
  

闽ICP备14008679号