XMLType是oracle数据库特有的数据类型可以用来存储一段xml,通过java(本文使用jdbc)插入XMLType根据sql中参数的类型通常有以下3种方法:
[color=red]本文使用的数据库为oracle10.2.1[/color]
一、String,客户端只需传递一个字符串参数,创建xmltype的任务完全交给数据库,此方法数据库的压力最大
二、CLOB,在客户端创建好CLOB传入数据库端通过oracle数据库的XMLTYPE()函数构造成XMLType类型的值,此方法客户端和数据库端同时承担了创建xmltype的任务,因此数据库的压力居中
三、XMLType,客户端传递一个XMLType给数据库,此方法将创建xmltype的任务完全交给了客户端,因此数据库的压力最小
以上三种方法通过插入20万条数据测试比较发现:
第一种方法:耗时最短,服务器cpu消耗最大
第二种方法:耗时最长,服务器cpu消耗居中
第三种方法:耗时居中,服务器cpu消耗最小
[b]如果有谁知道其他方法请务必留言,感激不尽![/b]
[table]|[url="http://s.click.taobao.com/a/qXMXdhyM2l4=-14390488"][img]http://image.taobao.com/bao/uploaded/http://img08.taobaocdn.com/bao/uploaded/i8/T1EU4qXmhdXXcIVTHb_095348.jpg_sum.jpg[/img][/url][url="http://s.click.taobao.com/a/qXMXdhyM2l4=-14390488"]皇冠信誉◆清风通讯-[b][size=medium]黑莓体验中心-BLACKBERRY[/size][/b]全面支持货到付款[/url][url="http://s.click.taobao.com/a/qXMXdhyM2l4=-14390488"][img]http://img.alimama.cn/images/tbk/cps/fgetccode_btn.gif[/img][/url][/table]
[b][size=medium][i][align=left][color=red][img]http://img.tongji.linezing.com/729225/tongji.gif[/img]真诚希望朋友们能留下宝贵意见,不甚感激![/color][/align][/i][/size][/b]
[color=red]本文使用的数据库为oracle10.2.1[/color]
一、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消耗最小
[b]如果有谁知道其他方法请务必留言,感激不尽![/b]
[table]|[url="http://s.click.taobao.com/a/qXMXdhyM2l4=-14390488"][img]http://image.taobao.com/bao/uploaded/http://img08.taobaocdn.com/bao/uploaded/i8/T1EU4qXmhdXXcIVTHb_095348.jpg_sum.jpg[/img][/url][url="http://s.click.taobao.com/a/qXMXdhyM2l4=-14390488"]皇冠信誉◆清风通讯-[b][size=medium]黑莓体验中心-BLACKBERRY[/size][/b]全面支持货到付款[/url][url="http://s.click.taobao.com/a/qXMXdhyM2l4=-14390488"][img]http://img.alimama.cn/images/tbk/cps/fgetccode_btn.gif[/img][/url][/table]
[b][size=medium][i][align=left][color=red][img]http://img.tongji.linezing.com/729225/tongji.gif[/img]真诚希望朋友们能留下宝贵意见,不甚感激![/color][/align][/i][/size][/b]