Oracle多用户同时修改同一记录,怎样保证该客户记录

前端之家收集整理的这篇文章主要介绍了Oracle多用户同时修改同一记录,怎样保证该客户记录前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
  1. 首先你要了解什么叫做 “事务 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,sal from emp where empno= 7900;
    EMPNO ENAME SAL
    ---------- ---------- ----------
    7900 JAMES 6000
    现在只有A用户能够查看到,修改后的数据。

    3. B用户进行查看:
    sql> select empno,191); text-decoration:none">JAMES 950

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

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

猜你在找的Oracle相关文章