sql2005 批量更新问题的解决方法
更新时间:2010年03月13日 12:39:40 作者:
这些天因为有数据割接的需求,于是有要写关于批量更新的程序。我们的数据库使用的是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;
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;
相关文章
MSSQL2005在networkservice权限运行附加数据库报(Microsoft SQL Server,错误:
无法打开物理文件 "XXXXXXXXXXXXX"。操作系统错误 5:"5(拒绝访问。)"。 (Microsoft SQL Server,错误: 5120)2012-11-11
SQL Server 2005 Express 安装失败解决办法
本人重装vs2005后,sql sever 2005 express却一直安装不上,造成写好的网页无法运行。多次卸载重装无果2009-03-03
Win7 32/64位系统下安装SQL2005和SP3补丁安装教程[图文]
今天有网友问win7 64系统下能安装sql2005吗,答案是肯定了,大家可以参考下面这篇文章试试2012-12-12
sqlserver 2008手工修改表结构,表不能保存的问题与解决方法
今天晚上休息,写一个小程序,用的是sql server 2008,手工建立了一些表,然后我回头想到了表字段中有一些需要增加一列,回头我就插入一列,结果我保存的时候却弹出如下窗口2010-04-04
Windows2003 SQL2005添加系统用户修改系统登录密码
这篇文章主要介绍了Windows2003 SQL2005添加系统用户修改系统登录密码的方法,大家如何忘记了系统的密码可以试试这个方法2013-11-11
PowerDesigner中如何导入SQL Server数据库
这篇文章向我们介绍了如何导入SQL Server数据库到PowerDesigner中的详细步骤说明,并附带图片介绍,需要了解的朋友可以参考下2015-07-07


最新评论