java操作XMLType的几种方法

     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消耗最小

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

皇冠信誉◆清风通讯-黑莓体验中心-BLACKBERRY全面支持货到付款

真诚希望朋友们能留下宝贵意见,不甚感激!

你可能感兴趣的:(java,oracle,sql,BlackBerry,黑莓)