首先注意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的驱动问题,很多同志可能还是在用的驱动呢,没有用批量更新的程序没有多大问题,可是一旦用了批量更新,出现很多问题, 反正数据库很卡,慢。还可以更新不了哦。 我强烈建议大家更新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:
推荐整理分享sql2005 批量更新问题的解决方法(sql语句批量更新),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:sqlsession批量更新,sqlserver批量更新数据,sql语句批量更新,sql 批量更新字段,sqlsugar批量更新,sql 批量更新字段,sqlserver批量更新,sql语句批量更新,内容如对您有帮助,希望把文章链接给更多的朋友!
一步一步教你创建SQL 计划任务应用图解教程 使用sql的计划任务可以处理一些特殊环境的数据,除了使用windows系统的计划任务来定时处理,不过要配合程序才行,有些事情可以直接使用sql本身的计
sqlserver 手工修改表结构,表不能保存的问题与解决方法 如果点击保存文本文件将会弹出保存文本文件的对话框口,保存的文本文件中的内容是如下:/*年4月5日0::用户:服务器:LONGGEL数据库:longgel应用程序
Sqlserver 使用XML一次更新多条记录的方法 我想很多人都知道,在oracle里面,存储过程里面可以传入数组(如int[]),也就是说,可以传多条记录到数据,从而一起更新。减少数据库的请求次数