欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

java操作XMLType的几种方法 博客分类: Java\Eclipse Plugin\Birt JavaBlackBerry黑莓OracleSQL 

程序员文章站 2024-03-01 10:37:40
...
     XMLType是oracle数据库特有的数据类型可以用来存储一段xml,通过java(本文使用jdbc)插入XMLType根据sql中参数的类型通常有以下3种方法:
     本文使用的数据库为oracle10.2.1
     一、String,客户端只需传递一个字符串参数,创建xmltype的任务完全交给数据库,此方法数据库的压力最大
        
             String sql = "insert into xmltable (XML) values(sys.xmlType.createXML(?))";
             String xmldata = "<label>This is an XML fragment</label>";
             ps.setString(1, xmldata);
             ps.executeUpdate();
         

     二、CLOB,在客户端创建好CLOB传入数据库端通过oracle数据库的XMLTYPE()函数构造成XMLType类型的值,此方法客户端和数据库端同时承担了创建xmltype的任务,因此数据库的压力居中
        
             Connection conn = ... ;//获得Connection
             PreparedStatement ps = ...;//获得PreparedSatement
     
             String sql = "insert into xmltable (XML) values(XMLType(?))";
             String xmldata = "<label>This is an XML fragment</label>";
     
             //通过conn创建CLOB
             CLOB tempClob = CLOB.createTemporary(conn, false, CLOB.DURATION_SESSION); 
             //打开CLOB
             tempClob.open(CLOB.MODE_READWRITE);
             //获得writer
             Writer clobWriter = clob.setCharacterStream(100);
             //写入数据
             clobWriter.write(xmldata);
             //刷新
             clobWriter.flush();
             //关闭writer
             clobWriter.close();
             //关闭CLOB
             tempClob.close();
     
             ps.setObject(1, tempClob);
             ps.executeUpdate();
         

     三、XMLType,客户端传递一个XMLType给数据库,此方法将创建xmltype的任务完全交给了客户端,因此数据库的压力最小
        
             Connection conn = ... ;//获得Connection
             PreparedStatement ps = ...;//获得PreparedSatement
     
             String sql = "insert into xmltable (XML) values(?)";
             String xmldata = "<label>This is an XML fragment</label>";
             //创建一个XMLType对象
             XMLType xmltype = XMLType.createXML(conn, xmldata);
     
             ps.setObject(1, xmltype);
             ps.executeUpdate();
         

         以上三种方法通过插入20万条数据测试比较发现:
                                                     第一种方法:耗时最短,服务器cpu消耗最大
                                                     第二种方法:耗时最长,服务器cpu消耗居中
                                                     第三种方法:耗时居中,服务器cpu消耗最小

如果有谁知道其他方法请务必留言,感激不尽!

java操作XMLType的几种方法
            
    
    博客分类: Java\Eclipse Plugin\Birt JavaBlackBerry黑莓OracleSQL 皇冠信誉◆清风通讯-黑莓体验中心-BLACKBERRY全面支持货到付款java操作XMLType的几种方法
            
    
    博客分类: Java\Eclipse Plugin\Birt JavaBlackBerry黑莓OracleSQL 

java操作XMLType的几种方法
            
    
    博客分类: Java\Eclipse Plugin\Birt JavaBlackBerry黑莓OracleSQL 真诚希望朋友们能留下宝贵意见,不甚感激!