@SuppressWarnings("rawtypes")
public void execBq(BatchBean bb, BlockingQueue<Map> bq, boolean closeConnetction) {
PreparedStatement pst = null;
try {
conn.setAutoCommit(false);
Long beginTime = System.currentTimeMillis();
pst = conn.prepareStatement(bb.getSql());
int k = bq.size();
for (int i = 1; i <= k; i++) {
Map s = bq.take();
for (int j = 0; j < bb.getParam().length; j++) {
pst.setString(j + 1, (String) s.get(bb.getParam()[j]));
}
pst.addBatch();
if (i % Storage.BUFFER_COUNT == 0 || i == k) {
pst.executeBatch();
conn.commit();
pst.clearBatch();
if(i==k){
System.out.println("本次更新了" +k% Storage.BUFFER_COUNT+"条数据");
}else{
System.out.println("本次更新了" +Storage.BUFFER_COUNT+"条数据");
}
//特别注意这里,这里看似好像是多余的;其实不然;
//因为每次执行 executeBatch 都会开启一次游标;到最后的时候//只执行了一次,过程当中我们分批执行了N次;所以应该是关闭N次,重新打开N次;
if(pst!=null){
System.out.println("关了了再开");
pst.close();
pst = conn.prepareStatement(bb.getSql());
}
}
}
Long endTime = System.currentTimeMillis();
System.out.println("pst+batch:" + (endTime - beginTime) / 1000 + "秒");
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
pst.close();
System.out.println("关闭一个连接");
if (closeConnetction) {
//pst.close();
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}
关键是 这里的 pst.close(); 原本是写在里面的。如果写在里面,多线程的时候一直未关闭;一直保持住;所以会报错;我不关闭连接,但并代表我不关闭 preparstatement
select count(*) from v$open_cursor;
可以监控游标语句;改完之后,我的游标数量的确就没有再超了;
//特别注意这里,这里看似好像是多余的;其实不然;
//因为每次执行 executeBatch 都会开启一次游标;到最后的时候//只执行了一次,过程当中我们分批执行了N次;所以应该是关闭N次,重新打开N次;
分享到:
相关推荐
ora-00604 错误 解决 方法 ora-00604 错误 解决 方法 ora-00604 错误 解决 方法 ora-00604 错误 解决 方法 ora-00604 错误 解决 方法ora-00604 错误 解决 方法
ORA-00604: 递归SQL层1出现错误 ORA-03106: 致命的双工通信协议错误 ORA-02063: 紧接着line(源于dblink) 以及 ORA-04052: 在查找远程对象时出错 ORA-00604: 递归SQL层1出现错误 ORA-03120: 双工转换例行程序:整数...
本文对ORA-01000_maximum_open_cursors_exceeded_超出打开游标的最大数的原因和解决方案有详细描述
ora-01033:oracle initialization or shutdown in progress 解决方法 ora-01033:oracle initialization or shutdown in progress 解决方法 ora-01033:oracle initialization or shutdown in progress 解决方法 ora-...
在运行查询SELECT * FROM V$SESSION 会出现ORA-29275:部分多字节字符的错误,这是什么原因开始我不得其解,网上也没有介绍什么好办法。本文给出答案。
ORA-12154: TNS: 无法解析指定的连接标识符的解决方法
ORA-32001:write to spfile requested but no spfile is in use请求写入spfile,但没有使用spfile的解决方法 在输入以下语句中报了这样的错误: SQL>alter system set control_files=’/u01/app/oracle/oradata/prod/...
ORA-00031:标记要终止的会话解决方案; ORA-00031:标记要终止的会话解决方案;
ORA-01036:非法的变量名/编号 oracle特有的错误
oracle12c程序连接时异常: ORA-01017: 用户名/口令无效; 登录被拒绝 的解决方案。
调整参数后引起,ORA-00838: Specified value of MEMORY_TARGET is too small, needs to be at least 3 2768M 的解决方案
Drop goldengate用户时,报ORA-00604 ORA-20782 ORA-06512错误
项目OracleDefi ORA是Oracledefi项目的代币姓名: oracledefi.finance象征: 欧拉总供应量: 100.000 ORA未来的代币发行: 不可以,在部署时会创建最大令牌数。 部署令牌后,将无法访问“薄荷糖”功能。在Uniswap上...
NULL 博文链接:https://3w1h.iteye.com/blog/1211779
错误描述:oracle远程连接服务器出现 ORA-12170 TNS:连接超时 错误检查:有很多是oracle自身安装的问题,但是我这里服务器配置正常,监听正常,服务正常,远程可以ping通服务器。 这里主要是防火墙问题,解决办法: ...
oracle 12 c ORA-01017: 用户名/口令无效; 登录被拒绝
Oracle 回收站功能,彻底删除表ORA-00933:SQL command not properly ended,由于删除触发器引起的。数据交换不能再建触发器。
-- 解决ORA-00904: "WMSYS"."WM_CONCAT": 标识符无效 的文件包....... -- 解决ORA-00904: "WMSYS"."WM_CONCAT": 标识符无效 的文件包....... -- 解决ORA-00904: "WMSYS"."WM_CONCAT": 标识符无效 的文件包....... ...
最近在工作中遇到了一个问题,错误是Oracle dbca时报错:ORA-12547: TNS:lost contact,通过查找相关的资料终于找到了解决的方法,下面分享给大家,话不多说了,来一起看看详细的介绍吧。 环境: OS:RHEL6.5 x86-...
在oracle里面运行一下,解决Exception java.sql.SQLException ORA-00600 内部错误代码