sql2005批量更新数据的问题

发布时间:2020-12-21编辑:脚本学堂
本文介绍了sql server 2005数据库中批量更新数据的方法,注意Statement和PreparedStatement的问题 ,需要的朋友参考下。

在sql数据库中实现批量更新的程序,数据库使用的是SQLSERVER2005,碰到了一些问题来分享下。

首先,注意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;