欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【SQL Server 2005数据库批量更新解决办法】,下面是详细的分享!
SQL Server 2005数据库批量更新解决办法
这些天因为有数据割接的需求,于是有要写关于批量更新的程序。我们的数据库使用的是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;
我上传了1.2的驱动 点击下载
以上所分享的是关于SQL Server 2005数据库批量更新解决办法,下面是编辑为你推荐的有价值的用户互动:
相关问题:sql server 2005 update 查询 数据计算 批量更新
答:select t1.id,(t1.kaipan/t2.shoupan-1)*100 kaipanbi into #tmp from (select ROW_NUMBER() over(order by riqi) vid,id,riqi,kaipan from table_1) t1 left join (select ROW_NUMBER() over(order by riqi)-1 vid,id,riqi,shoupan from table_... >>详细
相关问题:SqlServer2005批量更新数据的效率问题。
答:貌似没办法。唯一能做的就是把表索引加上。 所以与其把思路放在更新这么多个项目上。不如考虑为什么一定要30秒通讯一次,通讯10-20个 >>详细
相关问题:SqlServer2005中,如何批量更新不同行列里面的字符?
答:用replace函数 update Table set S_Text=Replace(字段,'gs01','你要替换的值') 你可以先更新一条试试看,也可以先用事务来执行,天数值用一样的方法 >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
