Oracle事务的ACID特性

原子性Atomicity:事务中的所有动作要么都发生,要么都不发生。
一致性Consistency:事务将数据库从一种状态转变为下一种一致状态。
隔离性Isolation:一个事务的影响在该事务提交前对其他事务时不可见的。
持久性Durability:事务一旦提交,其影响就是永久性的。

事务控制语句

事务隐式开始

事务必须显示结束(Commit、Rollback)

Commit 会结束事务,并使得已做的修改持久的保存在数据库中
Rollback 会结束事务,并撤销这个事务所做的修改。撤销动作需要读取回滚段中的信息,并把数据恢复到事务开始之前的状态
Savepoint 创建标记点(marked point),一个事务可以有多个标记点
Rollback To<Savepoint> 把事务回滚到指定的标记点,但是不回滚此标记点之前的工作。
Set transaction 允许设置不同的事务属性,如事务的隔离级别以及事务时只读的还是可读可写的。

原子性

语句级原子性

SQL> create table t2(cnt int);

Table created.

SQL> insert into t2 values(0);

1 row created.

SQL> create table t(x int check(x>0));

Table created.

SQL> create or replace trigger t_trigger
  2  before insert or delete on t for each row
  3  begin
  4    if ( inserting ) then
  5        update t2 set cnt=cnt+1;
  6    else
  7        update t2 set cnt=cnt-1;
  8    end if;
  9    dbms_output.put_line('I fired and updated'||sql%rowcount||'rows');
10  end;
11  /

SQL> set serveroutput on
SQL> select * from t2;

CNT
----------
     0

SQL> select * from t;

no rows selected

SQL> insert into t values(1);
I fired and updated1rows

1 row created.

SQL> insert into t values(-1);
I fired and updated1rows
insert into t values(-1)
*
ERROR at line 1:
ORA-02290: check constraint (EODA.SYS_C007120) violated

SQL> select * from t2;

CNT
----------
     1

过程级原子性
Oracle把PL/SQL匿名块也当做是语句

SQL> create or replace procedure p
  2  as
  3  begin
  4     insert into t values(1);
  5     insert into t values(-1);
  6  end;
  7  /

Procedure created.

SQL> delete from t;

0 rows deleted.

SQL> update t2 set cnt=0;

1 row updated.

SQL> commit;

Commit complete.

SQL> select * from t;

no rows selected

SQL> select * from t2;

CNT
----------
     0

SQL> begin
  2  p;
  3  end;
  4  /
begin
*
ERROR at line 1:
ORA-02290: check constraint (EODA.SYS_C007120) violated
ORA-06512: at "EODA.P", line 5
ORA-06512: at line 2

SQL> set serveroutput on
SQL> /
I fired and updated1rows
I fired and updated1rows
begin
*
ERROR at line 1:
ORA-02290: check constraint (EODA.SYS_C007120) violated
ORA-06512: at "EODA.P", line 5
ORA-06512: at line 2

SQL> select * from t;

no rows selected

SQL> select * from t2;

CNT
----------
     0

事务级原子性
DDL与原子性

持久性

COMMIT的WRITE扩展
      COMMIT WRITE WAIT (默认)必须等待redo写到磁盘才返回消息给客户端
      COMMIT WRITE NOWAIT 异步提交,redo条目还没写入磁盘就返回消息给客户端
非分布式PL/SQL代码块中的COMMIT
      在后台以异步的方式执行
      即commit=commit write nowait

完整性约束和事务

Immediate约束  
     整个SQL语句得到处理后立即检查

SQL> create table t(x int unique);

Table created.

SQL> insert into t values(1);

1 row created.

SQL> insert into t values(2);

1 row created.

SQL> commit;

Commit complete.

SQL> update t set x=x-1;

2 rows updated.

Deferrable约束和级联更新

SQL> create table parent
  2  (pk int primary key)
  3  /

Table created.

SQL> create table child
  2  (fk constraint child_fk_parent
  3      references parent(pk)
  4      deferrable
  5      initially immediate
  6  )
  7  /

Table created.

SQL> insert into parent values(1);

1 row created.

SQL> insert into child values(1);

1 row created.

SQL> update parent set pk=2;
update parent set pk=2
*
ERROR at line 1:
ORA-02292: integrity constraint (EODA.CHILD_FK_PARENT) violated - child record found

由于约束是IMMEDIATE模式,update失败,换为deferred模式
SQL> set constraint child_fk_parent deferred;

Constraint set.

SQL> update parent set pk=2;

1 row updated.

SQL> set constraint child_fk_parent immediate;
set constraint child_fk_parent immediate
*
ERROR at line 1:
ORA-02291: integrity constraint (EODA.CHILD_FK_PARENT) violated - parent key not found

SQL> update child set fk=2;

1 row updated.

SQL> set constraint child_fk_parent immediate;

Constraint set.

SQL> commit;

Commit complete.

不好的事务习惯

在循环中提交
   1.性能影响

SQL> create table t as select * from all_objects;

Table created.

SQL> exec dbms_stats.gather_table_stats(user,'T');

PL/SQL procedure successfully completed.

SQL> variable n number
SQL> exec :n:=dbms_utility.get_cpu_time;

PL/SQL procedure successfully completed.

SQL> update t set object_name=lower(object_name);

17977 rows updated.

SQL> exec dbms_output.put_line((dbms_utility.get_cpu_time-:n)||' cpu hsecs...');
25 cpu hsecs...

PL/SQL procedure successfully completed.

SQL> exec :n:=dbms_utility.get_cpu_time;

PL/SQL procedure successfully completed.

BEGIN
   FOR x IN (SELECT ROWID rid, object_name, ROWNUM r FROM t)
   LOOP
      UPDATE t
         SET object_name = LOWER (x.object_name)
       WHERE ROWID = x.rid;

IF (MOD (x.r, 100) = 0)
      THEN
         COMMIT;
      END IF;
   END LOOP;

COMMIT;
END;

/

PL/SQL procedure successfully completed.

SQL> exec dbms_output.put_line((dbms_utility.get_cpu_time-:n)||' cpu hsecs...');
108 cpu hsecs...

PL/SQL procedure successfully completed.

SQL> exec :n:=dbms_utility.get_cpu_time;

PL/SQL procedure successfully completed.

DECLARE
   TYPE ridArray IS TABLE OF ROWID;

TYPE vcArray IS TABLE OF t.object_name%TYPE;

l_rids    ridArray;
   l_names   vcArray;

CURSOR c
   IS
      SELECT ROWID, object_name FROM t;
BEGIN
   OPEN c;

LOOP
      FETCH c
      BULK COLLECT INTO l_rids, l_names
      LIMIT 100;

FORALL i IN 1 .. l_rids.COUNT
         UPDATE t
            SET object_name = LOWER (l_names (i))
          WHERE ROWID = l_rids (i);

COMMIT;
      EXIT WHEN c%NOTFOUND;
   END LOOP;

CLOSE c;
END;

/

PL/SQL procedure successfully completed.

SQL> exec dbms_output.put_line((dbms_utility.get_cpu_time-:n)||' cpu hsecs');
26 cpu hsecs

PL/SQL procedure successfully completed.

2.Snapshot Too Old
   3.可重启的过程需要复杂的逻辑

使用自动提交

分布式事务

自治事务:允许创建一个事务中的事务,它能独立于其父事务提交或者回滚。

Oracle事务的更多相关文章

  1. 浅谈Oracle事务【转载竹沥半夏】

    浅谈Oracle事务[转载竹沥半夏] 所谓事务,他是一个操作序列,这些操作要么都执行,要么都不执行,是一个不可分割的工作单元.通俗解释就是事务是把很多事情当成一件事情来完成,也就是大家都在一条船上,要 ...

  2. Oracle事务之一:锁和隔离

    Oracle事务之一:锁和隔离 一. 事务概述 事务管理是数据库处理的核心.数据库既要保证用户能并发地执行事务,还要保证数据库的一致性. 当第一条可执行的SQL开始执行,就隐形地开始了一个事务,直到遇 ...

  3. oracle事务和锁

    数据库事务概括 1. 说明 一组SQL,一个逻辑工作单位,执行时整体修改或者整体回退. 2.事务相关概念 1)事务的提交和回滚:COMMIT/ROLLBACK 2)事务的开始和结束 开始事务:连接到数 ...

  4. oracle事务和锁(转)

    If you use a SET TRANSACTION statement, then it must be the first statement in your transaction. How ...

  5. oracle事务(转)

    今天温习oracle事务,记录如下: 事务定义            事务是保持数据的一致性,它由相关的DDL或者DML语句做为载体,这组语句执行的结果要么一起成功,要么一起失败.        我们 ...

  6. oracle 事务 与 提交

    Oracle事务 一般事务(DML)即数据修改(增.删.改)的事务事务会将所有在事务中被修改的数据行加上锁(行级锁),来阻止其它人(会话)同时对这些数据的修改操作.当事务被提交或回滚后,这些数据才会被 ...

  7. Oracle事务隔离级别处理差异

    Oracle事务隔离是事务读操作不同程度的数据隔离,分为READ_UNCOMMITTED.READ_COMMITTED(默认).SERIALIZABLE. Oracle事务隔离级别SERIALIZAB ...

  8. Oracle事务与锁

    Oracle事务与锁 2017-12-13 目录 1 数据库事务概括  1.1 事务定义  1.2 事务生命周期  1.3 事物的特性  1.4 死锁2 事务相关语句  2.1 事务相关语句概括  2 ...

  9. 转:oracle 事务

    原文地址:http://blog.csdn.net/junmail/article/details/5556561 关于Oracle事务的总结 1.什么是事务,事务的特性是什么? 事务的任务便是使数据 ...

随机推荐

  1. href,src,url 整理

    一.href 和 src 的定义及区别 href:Hypertext Reference(超文本引用),指定网络资源的位置,从而在当前元素或者当前文档和由当前属性定义的需要的锚点或资源之间定义一个链接 ...

  2. JVM内存分配策略

    在 JVM内存垃圾回收方法 中,我们已经详细讨论了内存回收,但是,我们程序中生成的对象是如何进行分配的呢?以下所述针对的是HotSpot虚拟机. 1.Java堆结构 以HotSpot为例,如下图: H ...

  3. 内网穿透神器(ngrok)服务端部署【分享一台自己的ngrok服务器】【多平台】

    Ngrok为何物 “ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道.ngrok 可捕获和分析所有通道上的流量,便于后期分析和重放.”这是百度百科上给Ng ...

  4. apache_commons 之 双向Map DualHashBidiMap (使用及源码)

    在项目当中,经常出现需要根据Key值获取value:而且要求根据value获取key值,其实在commons-collections包中已经提供了此集合类.就是DualHashBidiMap类. (官 ...

  5. Linux下安装 MySQL

    Ubuntu环境 使用二进制安装包安装,相对简单绿色 1.到官网下载二进制压缩包http://dev.mysql.com/downloads/mysql/ 2.选择需要的版本 目前最新为5.7.之后选 ...

  6. 将博客搬至CSDN

    将博客搬至CSDN将博客搬至CSDN将博客搬至CSDN将博客搬至CSDN

  7. SQL语句判断数据库、表、字段是否存在

    from master..sysdatabases where name='TestDB')    print 'TestDB存在'else    print 'TestDB不存在' --判断表[Te ...

  8. 移动开发框架剖析(二) Hammer专业的手势控制

    浏览器底层并没有给元素提供类似,单击,双击,滑动,拖动这些直接可以用的控制接口,一切的手势动作都只能通过模拟出来.移动端浏览器唯一给我们提供的就只是mousedown -> mousemove ...

  9. 面向科学计算的Python IDE--Anaconda

    1.下载 2.安装,假定路径为D:/Anaconda 3.在命令行中查看已安装的包及其版本 D: cd Anaconda conda list 结果: # packages in environmen ...

  10. svn 版本迁移到 git 仓库

    1.拉取 svn代码并转成 git 版本 git svn fetch http://svn.qtz.com/svn/qtz_code/java/qtz_sm/project/qtz_sm -Auser ...