CREATE OR REPLACE PROCEDURE BATCHINSERTSK_DEVICE_RECORD1
(
      xmlstr  IN clob,    
      v_commits out number,
      p_rows   Out Sys_Refcursor
)
AS
iscz number;
zqcomit number;
pchsc varchar2(50);

BEGIN

savepoint sp01;  --设置回退点
v_commits:=0;     --v_counts初始值 0

--生成批次号,用于记录请求的唯一标识
select to_char(systimestamp,'yyyymmddhh24missff3') into pchsc  from dual;

-- 循环解析后的xml数据,逐条验证是否重复
 for xsk in  (select * from  ( SELECT
              EXTRACTVALUE(VALUE(t),'/u/i')    i   --recover_uuid
              ,EXTRACTVALUE(VALUE(t),'/u/t')   t   --register_unit_uuid
              ,EXTRACTVALUE(VALUE(t),'/u/l')   l   --device_type
              ,EXTRACTVALUE(VALUE(t),'/u/b')   b   --device_id
              ,EXTRACTVALUE(VALUE(t),'/u/n')   n   --nsrsbh
              ,EXTRACTVALUE(VALUE(t),'/u/m')   m   --nsrmc
              ,EXTRACTVALUE(VALUE(t),'/u/h')   h   --recover_people
              ,to_date(EXTRACTVALUE(VALUE(t),'/u/r'),'yyyy/MM/dd') r  --recover_date
              ,EXTRACTVALUE(VALUE(t),'/u/y')   y   --recover_reason
              ,EXTRACTVALUE(VALUE(t),'/u/p')   p   --recover_remark
              ,EXTRACTVALUE(VALUE(t),'/u/s')   s   --status
              ,EXTRACTVALUE(VALUE(t),'/u/ot')  ot  --hold_unit
              ,EXTRACTVALUE(VALUE(t),'/u/ht')  ht  --history_hold_unit
              ,EXTRACTVALUE(VALUE(t),'/u/e')   e   -- register_people
    FROM TABLE(XMLSEQUENCE(EXTRACT(
    XMLTYPE(xmlstr), '/d/u')))
    t) xat )
    
    loop
    --从正式表中遍历插入的数据,取出和 解析xml后的结果集的重复数据  。取出符合条件的数据条数 赋值变量 iscz
       select count(1) into iscz from sk_device_recover_tmp sk where sk.device_type=xsk.l and sk.device_id=xsk.b;
       
     
       if iscz=0 then          --如果数据为0,没有重复数据。那么插入正式表      
           insert into
        sk_device_recover_tmp r (
          r.recover_uuid,
          r.register_unit_uuid,
          r.device_type,
          r.device_id,
          r.nsrsbh,
          r.nsrmc,
          r.recover_people,
          r.recover_date,
          r.recover_reason,
          r.recover_remark,
          r.status,
          r.hold_unit,
          r.history_hold_unit,
          r.register_people
        )
        values (xsk.i,xsk.t,xsk.l,xsk.b,xsk.n,xsk.m,xsk.h,xsk.r,xsk.y,xsk.p,xsk.s,xsk.ot,xsk.ht,xsk.e) ;        
        v_commits:=v_commits+1;        --v_commits依次加1
        zqcomit:=zqcomit+1;          --zqcomit依次加1
        dbms_output.put_line(zqcomit);
         
                   if mod(zqcomit,100)=0  then  --分批提交
                      commit;
                   end if;

else
         --把重复的数据先放到表中临时存储,使用批次号标记
           insert into admin_work_area_tmp values(xsk.l,xsk.b,pchsc);
         end if;
               
   end loop;

--返回xml中和数据库中重复的数据,使用批次号查询  
open p_rows for select * from admin_work_area_tmp where pch=pchsc;
--删除当前批次号的数据
delete  admin_work_area_tmp where pch=pchsc;
commit;
v_commits:=v_commits+1;

--异常处理
exception
  when others then
      v_commits:=0;
      dbms_output.put_line(sqlcode||sqlerrm);
    rollback to savepoint sp01;
    
--xml字符串 示例 <d><u><i>123456654321555</i><t>caee3254e0e84384a24067ea510cfa74</t><l>1</l><b>2534556654321</b><n>123456</n><m>纳税人</m><h>回收人</h><r>2015/09/28</r><y>1</y><p>wqerqwr</p><s>1</s><ot>57106214a6f048989aa38a5fd80c7ba3</ot><ht>57106214a6f048989aa38a5fd80c7ba3</ht><e>1130000001</e></u></d>

end;
/

创建 中转表 正式表
create table  SK_DEVICE_RECOVER_tmp
(
  recover_uuid       VARCHAR2(32) not null,
  register_unit_uuid VARCHAR2(32),
  device_type        CHAR(1),
  device_id          VARCHAR2(20),
  nsrsbh             VARCHAR2(40),
  nsrmc              VARCHAR2(200),
  recover_people     VARCHAR2(200),
  recover_date       DATE,
  recover_reason     CHAR(1),
  recover_remark     VARCHAR2(200),
  status             CHAR(1),
  hold_unit          VARCHAR2(32),
  history_hold_unit  VARCHAR2(300),
  register_date      DATE default sysdate,
  is_error           CHAR(1) default 0,
  stock_label        CHAR(1) default 'N',
  pre_status         CHAR(1),
  register_people    VARCHAR2(100)
)

create table ADMIN_WORK_AREA_tmp
(
  l   NUMBER,
  b   VARCHAR2(50),
  pch VARCHAR2(50)
)
tablespace USERS
  pctfree 10
  initrans 1
  maxtrans 255
  storage
  (
    initial 64
    next 1
    minextents 1
    maxextents unlimited
  );

分享最近和同事处理的 解析XML的相关问题的更多相关文章

  1. 分享一个解析XML成为php数组的方法

    原文:分享一个解析XML成为php数组的方法 <?php /* * To change this template, choose Tools | Templates * and open th ...

  2. POPTEST老李分享DOM解析XML之java

    POPTEST老李分享DOM解析XML之java   Java提供了两种XML解析器:树型解释器DOM(Document Object Model,文档对象模型),和流机制解析器SAX(Simple ...

  3. 关于dom4j解析XML的问题分享

    最近在在做个程序需要将C#小工具转成java,因为需要涉及到操作xml文件所以需要引用dom4j: 使用dom4j解析XML时,要快速获取某个节点的数据,使用XPath是个不错的方法,dom4j的快速 ...

  4. 解析xml并且导入mysql

    https://www.zhihu.com/question/28139319 解析超过500G的xml 写入mysql,如何尽快写入? 解析超过500G的xml 写入mysql,如何尽快写入? 现在 ...

  5. java解析XML文件

    dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的.dom4j是一个非常非常优秀的Java XML API,具有性能优异.功能强大和极端易用使用的特点,同时它也是一个开放源 ...

  6. ACEXML解析XML文件——我是如何学习并在短时间内掌握一个库的使用方法的

    最近做的C++项目中需要使用xml文件保存一些信息,程序启动时会读取这些信息.最终经过主程的评测,决定使用ACEXML库来读取解析XML文件. 好吧,至于为什么选择ACEXML库,我就不说了.既然选择 ...

  7. 【Android学习笔记】XmlResourceParser解析xml文件

    最近学习Android时,需要用到解析XML文件里的数据,可以用XmlResourceParser来解析xml文件,正好将此记录下来. XmlResourceParser里常用的字段和方法 首先先给出 ...

  8. python 解析XML python模块xml.dom解析xml实例代码

    分享下python中使用模块xml.dom解析xml文件的实例代码,学习下python解析xml文件的方法. 原文转自:http://www.jbxue.com/article/16587.html ...

  9. 【iOS-cocos2d-X 游戏开发之九】Cocos2dx利用CCSAXParser解析xml数据&CCMutableDictionary使用与注意!

    本站文章均为李华明Himi原创,转载务必在明显处注明:转载自[黑米GameDev街区] 原文链接: http://www.himigame.com/iphone-cocos2dx/694.html ☞ ...

随机推荐

  1. 关于spring3中No Session found for current thread!and Transaction的配置和管理(转)

    今天我是特别的郁闷,本来项目做到一半,以前都好好的,结果下午就出现问题,苦逼的到现在才解决.它出现问题的时候都一声不坑, ,(天啦,现在才发现CSDN啥时候把QQ表情给整过来了)就在注册用户的时候,咦 ...

  2. linux内核学习-

    我的博客:www.while0.com 1.端口地址的设置主要有统一编址和独立编址.  cat /proc/ioports 可以查询linux主机的设备端口. 2.数据传输控制方式有循环查询,中断和D ...

  3. 【转】Android 驱动开发系列四

    原文网址:http://www.2cto.com/kf/201304/202040.html 时隔多日,终于都抽出时间来写blog了.废话不多说,接着上一篇,这里将介绍如何编写HAL层(硬件抽象层)对 ...

  4. 用Delphi7开发Web Service程序 转

        转:http://rosehacker.blog.51cto.com/2528968/450160 用Delphi7开发Web Service程序,并把服务程序放在IIS Web服务器上提供给 ...

  5. Windows进程

    一.Windows进程 1.进程 进程是一种容器,包含了应用程序实例的各种资源. 2.Windows进程的一些特点 2.1.进程中包含了执行代码等资源 2.2.进程都具有私有的地址空间 2.3.每个进 ...

  6. Render To Texel Baker

    今天仔细研究了 Shaowgun 示例中那个金黄色雕像所使用的光照纹理烘焙工具:“Render To Texel Baker”.因为要在移动设备展现比较逼真的光照效果,但是实时使用法线贴图并大量用于场 ...

  7. 4种字符串匹配算法:BS朴素 Rabin-karp(上)

    字符串的匹配的算法一直都是比较基础的算法,我们本科数据结构就学过了严蔚敏的KMP算法.KMP算法应该是最高效的一种算法,但是确实稍微有点难理解.所以打算,开这个博客,一步步的介绍4种匹配的算法.也是& ...

  8. octopress 如何添加youku视频和本地视频(octopress how to add a youku video or a local video)

    用octopress 官方的video tag 可以添加视频,但是由于国内经常使用的是youku,所以下面是如何添加youku视频到octopress的教程. 首先添加youku.rb文件到路径:oc ...

  9. codeforces 421d bug in code

    题目链接:http://codeforces.com/problemset/problem/421/D 题目大意:每个人说出自己认为的背锅的两个人,最后大BOSS找两个人来背锅,要求至少符合p个人的想 ...

  10. 趣解curl

    Curl是Linux下一个很强大的http命令行工具,其功能十分强大. 1) 二话不说,先从这里开始吧! $ curl http://www.linuxidc.com 回车之后,www.linuxid ...