首页数据库sql2005 批量更新问题的解决方法

sql2005 批量更新问题的解决方法

时间2024-02-28 23:06:03发布访客分类数据库浏览627
导读:收集整理的这篇文章主要介绍了sql2005 批量更新问题的解决方法,觉得挺不错的,现在分享给大家,也给大家做个参考。 首先注意statement 和PReparedstatement的问...
收集整理的这篇文章主要介绍了sql2005 批量更新问题的解决方法,觉得挺不错的,现在分享给大家,也给大家做个参考。 首先注意statement 和PReparedstatement的问题
Statement sm = cn.createstatement();
sm.addBatch(SQL1);
sm.addBatch(sql2);
...
sm.executeBatch()
用Statement的好处就是每次可以直接传一个SQL语句进去,不用管那么多。可是在数据量比较大的时候,应该会对效率有影响。不建议使用。
PreparedStatement ps = cn.preparedStatement(sql);
{
 ps.setXXX(1,xxx);
 ...
 ps.addBatch();
}
ps.executeBatch();
PreparedStatement是会预编译的,只要一条SQL,不断动态设值,然后addBatch(),在数据量大的时候比较好,非常建议使用。
还有就是JDBC的驱动问题,很多同志可能还是在用2000的驱动呢,没有用批量更新的程序没有多大问题,可是一旦用了批量更新,出现很多问题,
反正数据库很卡,慢。还可以更新不了哦。
我强烈建议大家更新JDBC驱动。
但是如果出现
SQLServerException: sp_cursoroPEn/sp_cursorprepare: 该语句参数只能是一个批或带有单个 SELECT 语句的存储过程,且不带 FOR brOWSE、COMPUTE BY 或变量赋值。
应该就是JDBC的版本问题,1.0的驱动有这个问题,好像不支持批量更新,我建议大家使用1.2
我测试过了,完全没有问题!
提供一些数据连接参数
jdbc.driverclassname:com.microsoft.sqlserver.jdbc.SQLServerDriver
jdbc.url:jdbc:sqlserver://127.0.0.1:1444; databaseName=fax; selectMethod=cursor;

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: sql2005 批量更新问题的解决方法
本文地址: https://pptw.com/jishu/632063.html
SQLserver 2005文件和文件组的作用说明 一步一步教你创建SQL 2005计划任务应用图解教程

游客 回复需填写必要信息