SQL Server 2005批量更新问题的解决方法
栏目:MSSQL 来源:网络 关注:0 时间:2019-08-21
最近因为有数据割接的需求,于是有要写关于批量更新的程序。我们的数据库使用的是SQL Server 2005,碰到了一些问题来分享下。
首先注意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驱动。
但是如果出现
SQL ServerException: sp_cursoropen/sp_cursorprepare: 该语句参数只能是一个批或带有单个 SELECT 语句的存储过程,且不带FOR BROWSE、COMPUTE BY或变量赋值。
应该就是JDBC的版本问题,1.0的驱动有这个问题,好像不支持批量更新,建议大家使用1.2。
一些数据连接参数
jdbc.driverClassName:com.Microsoft.SQL Server.jdbc.SQL ServerDriver
jdbc.url:jdbc:SQL Server://127.0.0.1:1444;databaseName=fax;selectMethod=cursor;
本文标题:SQL Server 2005批量更新问题的解决方法
本文地址:http://www.q0738.com/mssql/1373.html
- SQL Server 2005 ERROR:3145解决办法(备份集中的数据库备份与现有的数据库不同)
- SQL Server 2005的排名函数使用小结
- MSSQL Server 2005在networkservice权限运行附加数据库报(Microsoft SQL Ser...
- Win7安装软件时无法连接SQL Server解决方法
- SQL Server 2005的维护计划无法删除的解决方法
- SQL Server 2005 T-SQL Query学习(四)
- SQL Server 2005中使用SQL语句对xml文件和其数据的操作
- SQL Server 2005中使用row_number在一个查询中删除重复记录
- SQL Server 2005通用分页存储过程及多表联接应用
- SQLsever为标识列指定显式值