练习 DOUBLE INSERT

目标:从一张表取数据插入到另一张表中,此外需要为插入的目标表做一个应用级的日志表,也就是说在插入目标表的同时,还需要将相同的数据插入到日志表中。

在案例一中,我们给出了CREATE TRIGGER;OPEN CURSOR ;BULK INTO VARIABLE; DOUBLE INSERT; INSERT ALL 等方案。每个方案中也阐述了他的优缺点。

其中在DOUBLE INSERT,为了保证数据的一致性,又给出了四种思路,它们分别是锁,串行,临时表和as of 查询。下面将展现这四种思路SQL的展现。

当然DOUBLE INSERT 除了一致性的问题,还有原子性的问题,即有可有目标表和 日志表只成功了其它一个,或都没成功。关于原子性的问题。暂不讨论。

1.1思路一 锁

Drop table test;

Drop table T_ORG;

DROP TABLE T_LOG;

create table test as select * from all_objects ;

create table T_ORG as select * from all_objects  WHERE 1=2;

create table T_LOG as select * from all_objects WHERE 1=2;

#   --共享行专用(SRX):阻止其他事务操作,其会会话不能对test表进行DML操作

SQL> lock table t in exclusive mode nowait;

Locked Object:

OWNEROS_USER_NAME  OBJECT_NAME   SIDSERIAL# LOCKED_MODE LOGON_TIM

------- ------------- ----------------- ---------- ----------- -------

SYS     oracle        TEST       18         17           6 26-APR-19

SYS@test>INSERT INTO T_ORG SELECT * FROM TEST;

72183 rows created.

SYS@test>INSERT INTO T_LOG SELECT * FROM TEST;

72183 rows created.

新开一个窗口执行delete 操作产生等待:

SYS@test2>delete from test where OBJECT_ID <10 ;

直到原来窗口事务结束。

SYS@test>COMMIT ;

问题:影响其它事务

1.2思路二 串行事务面临的问题 ora-01555

Drop table test;

Drop table T_ORG;

DROP TABLE T_LOG;

create table test as select * from all_objects ;

create table T_ORG as select * from all_objects  WHERE 1=2;

create table T_LOG as select * from all_objects WHERE 1=2;

SYS@test>create undo tablespace undotbs datafile '/u01/app/oracle/oradata/test/undotbs.dbf' size 1M ;

Tablespace created.

SYS@test>alter system set undo_tablespace=undotbs;

SYS@test>show parameter undo ;

NAME                                 TYPE        VALUE

------------------------------------ ----------- ---------------------

undo_management                      string      AUTO

undo_retention                       integer     900

undo_tablespace                      string      UNDOTBS

declare

begin

INSERT INTO T_ORG SELECT * FROM TEST;

INSERT INTO T_LOG SELECT * FROM TEST;

Commit ;

end ;

/

*

ERROR at line 1:

ORA-30036: unable to extend segment by 8 in undo tablespace 'UNDOTBS'

ORA-06512: at line 3

SYS@test>select count(*) from T_ORG ;

COUNT(*)

----------

0

问题:UNDO 空间不足时,会报ORA-30036
     如果UNDO空间被覆盖会报ORA-01555

1.3思路三 临时表

Drop table test;

Drop table T_ORG;

DROP TABLE T_LOG;

create table test as select * from all_objects ;

create table T_ORG as select * from all_objects  WHERE 1=2;

create table T_LOG as select * from all_objects WHERE 1=2;

SYS@test>alter system set undo_tablespace=UNDOTBS1;

创建会话级别临时表:

SYS@test> create global temporary table temp1 on
Commit Preserve Rows  as select * from
all_objects where 1=2   ;

把数据写入到临时表:

SYS@test>INSERT INTO temp1 SELECT * FROM all_objects;

72186 rows created.

SYS@test>INSERT INTO T_ORG SELECT * FROM temp1;

72186 rows created.

SYS@test>INSERT INTO T_LOG SELECT * FROM temp1;

72186 rows created.

问题:相关于写了三次,读了三次,对性能影响较大

1.4思路四 AS OF 查询

Drop table test;

Drop table T_ORG;

DROP TABLE T_LOG;

create table test as select * from all_objects ;

create table T_ORG as select * from all_objects  WHERE 1=2;

create table T_LOG as select * from all_objects WHERE 1=2;

SYS@test>select current_scn from v$database  ;

CURRENT_SCN

-----------

975216

SYS@test>INSERT INTO T_ORG SELECT * FROM test as of
scn 975216;

72184 rows created.

SYS@test>INSERT INTO T_LOG SELECT * FROM test as of
scn 975216;

72184 rows created.

前提是你要提前查询SCN 或时间,而且还是查询插入了2次。

针对以上的问题,最好的解决方案是利用ORACLE 的insert all

<wiz_tmp_tag id="wiz-table-range-border" contenteditable="false" style="display: none;">

 
 
 
 

练习 DOUBLE INSERT的更多相关文章

  1. Mybatis与Spring整合,使用了maven管理项目,作为初学者觉得不错,转载下来

    转载自:http://www.cnblogs.com/xdp-gacl/p/4271627.html 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetype ...

  2. Mybatis3.x与Spring4.x整合(转)

    http://www.cnblogs.com/xdp-gacl/p/4271627.html 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetype:cre ...

  3. MyBatis入门学习教程-Mybatis3.x与Spring4.x整合

    一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetype:create -DgroupId=me.gacl -DartifactId=spring4-myba ...

  4. MyBatis学习总结(八)——Mybatis3.x与Spring4.x整合(转载)

      孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(八)--Mybatis3.x与Spring4.x整合 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: m ...

  5. SQL 行列倒置

    SQL的的行列倒置已经不是新知识了,但在博主的技术咨询期间,仍发现其实有很多人并不了解这块,所以在此专门写一篇博客记录.本文将以Mysql为例,并以数据采集指标信息获取为例子.在下面的例子,你可以在s ...

  6. MyBatis学习总结(八)——Mybatis3.x与Spring4.x整合

    一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetype:create -DgroupId=me.gacl -DartifactId=spring4-myba ...

  7. 扫描线 + 线段树 : 求矩形面积的并 ---- hnu : 12884 Area Coverage

    Area Coverage Time Limit: 10000ms, Special Time Limit:2500ms, Memory Limit:65536KB Total submit user ...

  8. [转]Mybatis3.x与Spring4.x整合

    原文地址:http://www.cnblogs.com/xdp-gacl/p/4271627.html 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetyp ...

  9. jdbc事务处理和连接池

    JDBC: * JDBC概念:Java DataBase Connectivity(Java数据库连接) SUN公司提供的一组连接数据库API. * JDBC开发步骤: * 1.注册驱动. * 2.获 ...

随机推荐

  1. springdata -----操作ES

    一:配置springdata-Es elasticseach-JPA.xml <?xml version="1.0" encoding="UTF-8"?& ...

  2. js教程系列32 :javascript-DOM节点操作

    1 DOM节点操作 1.1 创建节点 createElement() var createDiv = document.createElement("div"); 1.2 插入子节 ...

  3. UVa 1220 Party at Hali-Bula (树形DP,最大独立集)

    题意:公司有 n 个人形成一个树形结构,除了老板都有唯一的一个直系上司,要求选尽量多的人,但不能同时选一人上和他的直系上司,问最多能选多少人,并且是不是唯一的方案. 析:这个题几乎就是树的最大的独立集 ...

  4. ubuntu创建wifi热点plasma-nm

    第一步:安装 plasma-nm sudo apt-get install plasma-nm 第二步:启动程序 可以使用 Alt+F2 后,搜索 kde-nm-connection-editor 也 ...

  5. 编写高质量代码改善C#程序的157个建议——建议132:考虑用类名作为属性名

    建议132:考虑用类名作为属性名 一般来说,若果属性对应一个类型,应该直接用类型名命名属性名.如下: class Person { public Company Company { get; set; ...

  6. src.rpm格式的RHCS源码提取

    RHCS源码下载(地址1:地址2) 参考文档(RHCS安装也配置) RHCS源码提取(参考) 方法一: (1)rpm –ivh magma-plugins-1.0.15-3.src.rpm   执行r ...

  7. Javascript原型与对象等知识

    声明式函数定义: function add(m,n) { alert(m+n); } 这种方式等同于构造一个Function类的实例的方式: var add = new Function(" ...

  8. [Erlang00]:gen_server:reply/2

    --- gen_server:reply/2 reply(Client, Reply) –> Result      Types:     Client - see below     Repl ...

  9. 使用web API和NPOI导出Excel

    使用MVC controller输出excel的例子,自不待言,例子满天飞. 由于本项目使用的是Asp.net MVC API,因此在本项目使用API,实现了文件下载功能.代码的原理很简单,基本上是老 ...

  10. C# winform 自定义鼠标光标

    第一种:(调用系统API)首先引入两个命名空间代码如下: using System.Runtime.InteropServices;using System.Reflection;导入API代码如下: ...