zoukankan      html  css  js  c++  java
  • Oracle数据操纵和控制措辞详解2

       来历:天极网





    事件控制

      事件控制包括和谐对相通数据的多个同步的访问。当一个用户窜改了另一个用户正在运用的数据时,oracle运用事件控制谁可以操纵数据。

      事件

      事件透露表现工作的一个基本单元,是一系列作为一个单元被乐成或不乐成操纵的SQL语句。在SQL和PL/SQL中有很多语句退让调员控制事件。步调员可以:

       1、显式起头一个事物,选择语句级分比方性或事件级分比方性

       2、设置打消回滚点,并回滚到回滚点
     
       3、完成事件永世窜改数据或许保持修改。
      
      事件控制语句


    语句 用处
    Commit 完成事件,数据修改乐成并对其他用户开放
    Rollback 打消事件,打消统统操纵
    rollback to savepoint 打消在设置的回滚点今后的操纵
    set transaction 呼应事件或语句的分比方性;特别唐塞事件运用回滚段


      例:

    BEGIN
    UPDATE checking
    SET balance=balance-5000
    WHERE account='Kieesha';

    INSERT INTO checking_log(action_date,action,amount)
    VALUES (SYSDATE,'Transfer to brokerage',-5000);

    UPDATE brokerage
    SET cash_balance=cash_balance 5000
    WHERE account='Kiesha';

    INSERT INTO brokerage_log(action_date,action,amount)
    VALUES (SYSDATE,'Tracfer from checking',5000)

    COMMIT

    EXCEPTION
    WHEN OTHERS
    ROLLBACK

    END

      Savepoint 和 部门回滚(Partial Rollback)

      在SQL和PL/SQL中Savepoint是在一事件领域内的中央标记。屡屡用于将一个长的事件划分为小的部门。留存点Savepoint可标记长事件中的任何点,允准许回滚该点之后的操纵。在运用步调中屡屡运用Savepoint;比方一过程包括几个函数,在每个函数前可创设一个留存点,假设函数失落败,很轻易前往到每一个函数起头的状态。在回滚到一个Savepoint之后,该Savepoint之后所失落失落的数据关闭被释放。为了完成部门回滚可以用带TO Savepoint子句的ROLLBACK语句将事件回滚到指定的职位。

      例

    BEGIN

    INSERT INTO ATM_LOG(who,when,what,where)
    VALUES ('Kiesha',SYSDATE,'Withdrawal of  $100','ATM54')
    SAVEPOINT ATM_LOGGED;

    UPDATE checking
    SET balance=balance-100
    RETURN balance INTO new_balance;

    IF new_balance<0
    THEN
    ROLLBACK TO ATM_LOGGED;
    COMMIT
    RAISE insufficient_funda;
    END IF

    END

      关键字SAVEPOINT是可选的,以是下面两个语句是等价的:

    ROLLBACK TO ATM_LOGGED;
    ROLLBACK TO SAVEPOINT ATM_LOGGED;

      分比方性和事件

      分比方性是事物控制的关键慨念。操纵操纵了oracle 的分比方性模型,能使您更好的,更得当的运用事件控制。oracle议决分比方性保证数据只要在事件统统完成后妙技花腔被用户看见和运用。这项妙技对多用户数据库有复杂的作用。

      oracle屡屡运用语句级(state-level)分比方性,保证数据在语句的生命期之间是可见的但不克不及被窜改。事件由多个语句组成,当运用事件时,事物级(transaction-level)分比方性在整个事件生命期中保证数据对统统语句都是可见的。

      oracle议决SCN(syatem change number)实行分比方性。一个SCN是一个面向时分的数据库外部键。SCN只会添加不会添加,SCN透露表现了时分上的一个点,每个数据块都有一个SCN,议决角力盘算这个点实行操纵。

      事件级分比方性

      SET TRANSACTION 的一个作用是确保事件级分比方或语句级分比方中有一个实行。ORACLE运用这些术语:

       ISOLATION LEVEL READ COMMIT 透露表现语句级分比方

       ISOLATION LEVEL SERIALIZABLE 透露表现事件级分比方。

      例:

    SET TRANSACTION ISOLATION LEVEL READ COMMIT;

    SET TRANSACTION ISOLATION LEVEL READ COMMIT

      下面的语句也能确保事件级分比方:

    SET TRANSCATION READ ONLY
      任何计划在只读(READ ONLY)事件中修改数据的操纵城市抛出一个非常。然则,READ ONLY事件只能鄙人列语句中运用:

    SELECT(没有FOR UPDATE子句)
    LOCK TABLE
    SET ROLE
    ALTER SYSTEM
    ALTER ALARM

      纵然没有窜改任何数据,READ ONLY事件仍然必需运用一个COMMIT或ROLLBACK以结束整个事件。

      SET TRANSCTION的别的一个运用是在回滚时间接运用回滚段(ROLLBACK SEGMENT)。回滚段是ORACLE的一个特别的数据东西,回滚段的头部包括正在运用该回滚段事件的信息。当用户回滚事件(ROLLBACK)时,ORACLE将会运用回滚段中的数据前影像来将修改的数据规复到正本的值。oracle用round-robin给事件随机分配回滚段。一个年夜的事件可以分配任何回滚段,这能够会招致回滚段的年夜小变得很年夜。因而要阻止让年夜的事件随机分配回滚段。

      事件以SET TRANSACTION起头,象下面这样:

    SET TRANSACTION USE ROLLBACK SEGMENT rb_large;
      rb_large是一个年夜的回滚段的称谓,如今就给一个年夜的事件分配了一个年夜的回滚段,其他的小的回滚段将不由静态空间打点,这样就更有效率。

      下面我们看一个例子.我们有一个回滚段表空间年夜小是2G,在顶峰期间需求10个回滚段以满足用户的需求,这些顶峰在线用户只要小的事件。一周我们经受运转了4个年夜的事件,这些事件需求删除和加载数据,每一个打消需求1G,回滚段的年夜小如下:

    rb_large(initial 100M minextenta 2)

    rb1 (initial 1M next minextents 5)
    rb2 (initial 1M next minextents 5)
    rb3 (initial 1M next minextents 5)
    rb4 (initial 1M next minextents 5)
    rb5 (initial 1M next minextents 5)
    rb6 (initial 1M next minextents 5)
    rb7 (initial 1M next minextents 5)
    rb8 (initial 1M next minextents 5)
    rb9 (initial 1M next minextents 5)
    rb10 (initial 1M next minextents 5)

      统统的都非常得当的安排在2G的表空间中,假设我们缺省的round-robin给事件分配回滚段,4个年夜事件将有4个自力的回滚段,每个回滚段的年夜小将是1G,假设这样我们的2G表空间就不足,而数据库打点员就不得不在夜晚2点起来工作,每个事件都由以下面的语句起头:

    SET TRANSACTION USE ROLLBACK SEGMENT rb_large
      如今 4个事件重用相通的表空间,保正4个回滚段的表空间在2G以内。数据库打点员可以睡到天亮。




    版权声明: 原创作品,准许转载,转载时请务必以超链接形式标明文章 原始来因 、作者信息和本声明。否则将深究法则责任。

  • 相关阅读:
    常见面试测试要点
    怎样在 CentOS/RHEL 7/6 上安装和配置 Sendmail 服务器
    Cannot uninstall 'pyparsing'. It is a distutils installed project
    Linux下校验SHA1和MD5的方法
    Linux查看进程启动时间和运行多长时间
    sqlplus -S参数表示什么意思?
    dnspython模块报错 AttributeError: 'CNAME' object has no attribute 'address'
    CentOS7中安装pip的方法
    四则运算中遇到的一个问题
    动手动脑
  • 原文地址:https://www.cnblogs.com/zgqjymx/p/1976069.html
Copyright © 2011-2022 走看看