当前位置: 首页 > 图文教程 > 数据库 > 数据库技巧 > JDBC大批量写入数据到SQLServer2000,记录数大于10000

数据库技巧
一条DELETE语句
SQL SERVER 里的错误处理(try catch)
恢复 SQL 被注入后的数据代码
大数据量时提高分页的效率
数据库命名规范小结
where 子句的执行顺序
当数据库变慢时的解决方法
MYSQL 导入数据的几种不同
用户管理的备份(一致性备份、非一致性备份、脱机备份、联机备份)
多条件查询的程序
[原创]access mysql mssql 随机 10条数据的sql语句
Sybase 复制与热切换数据
Sql Server、Access数据排名的实现方法(例如:成绩排名)
sqlserver和oracle中对datetime进行条件查询的一点区别小结
在SQL Server和Oracle中创建job
Linux下 mysql oracle 简单使用手册
sql小计汇总 rollup用法实例分析
连续序号的 sql语句
SQLServer与Access常用SQL函数区别
JDBC 数据库常用连接 链接字符串

数据库技巧 中的 JDBC大批量写入数据到SQLServer2000,记录数大于10000


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-10   浏览: 415 ::
收藏到网摘: n/a

JDBC大批量写入数据到SQLServer2000,记录数大于10000
复制代码 代码如下:

SpObserver.putSp("sessionFactory1");
SimpleDateFormat fomat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Session s=null;
s=daoSupport.getSessionFactory().openSession();
Connection con=s.connection();
Statement stmt = null;
try {
stmt=con.createStatement();
con.setAutoCommit(false);
Iterator it=list.iterator();
int iCount = 1;
long start = System.currentTimeMillis();
while(it.hasNext()){
TResultWaterZId t = (TResultWaterZId)it.next();
StringBuffer sb = new StringBuffer();
sb.append("insert into T_result_water_z(schemeid,stcd,z,tm) values('");
sb.append(t.getSchemeid()).append("','").append(t.getStcd()).append("','");
sb.append(t.getZ()).append("','").append(fomat.format(t.getTm())).append("')");
stmt.addBatch(sb.toString());
if(iCount % 1000 == 0){
stmt.executeBatch();
stmt.clearBatch();
}
iCount++;
}
stmt.executeBatch();
stmt.clearBatch();
con.commit();
long end = System.currentTimeMillis();
System.out.println("addTResultWaterZId used time:"+(end-start));
stmt.close();
con.close();
} catch (SQLException e) {
try {
con.rollback();
} catch (SQLException e1) {
e1.printStackTrace();
}
e.printStackTrace();
}finally{
try {
stmt.close();
con.close();
} catch (SQLException e) {
e.printStackTrace();
}
}