2009-05-21
使用JDBC插入大量数据的性能测试
关键字: 性能测试
使用jdbc向数据库插入100000条记录,分别使用statement,PreparedStatement,及PreparedStatement+批处理3种方式进行测试:
//1.使用statement插入100000条记录
public void exec(Connection conn){
try {
Long beginTime = System.currentTimeMillis();
conn.setAutoCommit(false);//设置手动提交
Statement st = conn.createStatement();
for(int i=0;i<100000;i++){
String sql="insert into t1(id) values ("+i+")";
st.executeUpdate(sql);
}
Long endTime = System.currentTimeMillis();
System.out.println("st:"+(endTime-beginTime)/1000+"秒");//计算时间
st.close();
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
//2.使用PreparedStatement对象
public void exec2(Connection conn){
try {
Long beginTime = System.currentTimeMillis();
conn.setAutoCommit(false);//手动提交
PreparedStatement pst = conn.prepareStatement("insert into t1(id) values (?)");
for(int i=0;i<100000;i++){
pst.setInt(1, i);
pst.execute();
}
conn.commit();
Long endTime = System.currentTimeMillis();
System.out.println("pst:"+(endTime-beginTime)/1000+"秒");//计算时间
pst.close();
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
//3.使用PreparedStatement + 批处理
public void exec3(Connection conn){
try {
conn.setAutoCommit(false);
Long beginTime = System.currentTimeMillis();
PreparedStatement pst = conn.prepareStatement("insert into t1(id) values (?)");
for(int i=1;i<=100000;i++){
pst.setInt(1, i);
pst.addBatch();
if(i%1000==0){//可以设置不同的大小;如50,100,500,1000等等
pst.executeBatch();
conn.commit();
pst.clearBatch();
}
}
Long endTime = System.currentTimeMillis();
System.out.println("pst+batch:"+(endTime-beginTime)/1000+"秒");
pst.close();
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
在Oracle 10g中测试,结果:
1.使用statement耗时142秒;
2.使用PreparedStatement耗时56秒;
3.使用PreparedStatement + 批处理耗时:
a.50条插入一次,耗时5秒;
b.100条插入一次,耗时2秒;
c.1000条以上插入一次,耗时1秒;
通过以上可以得出结论,在使用jdbc大批量插入数据时,明显使用第三种方式(PreparedStatement + 批处理)性能更优。
分享到:
相关推荐
预定义的异常如NO_DATA_FOUND和 TOO_MANY_ROWS,以及自定义异常,都能帮助编写健壮的PL/SQL代码。 8. **表单和触发器**:PL/SQL可以创建表单和触发器,表单用于用户交互,触发器则在特定数据库事件(如INSERT、...
`EXCEPTION`关键字用于定义异常处理部分,常见的内置异常有`NO_DATA_FOUND`(未找到数据)、`TOO_MANY_ROWS`(返回过多行)和`OTHERS`(所有未明确捕获的异常)。 5. **游标**:游标允许PLSQL程序逐行处理查询结果...
7. **异常处理**:熟悉如何使用EXCEPTION块来捕获和处理运行时错误,如NO_DATA_FOUND、TOO_MANY_ROWS等。 8. **包(PACKAGE)**:了解包的概念,它是将相关的常量、变量、过程和函数组织在一起的方式,提高代码的...
例如,使用NOTFOUND、NO_DATA_FOUND、TOO_MANY_ROWS等预定义异常来处理特定错误。 5. **游标**:游标允许程序逐行处理查询结果,是PL/SQL中处理大量数据的重要工具。它们可以与循环结合,实现对结果集的迭代操作。 ...
预定义的异常如NO_DATA_FOUND、TOO_MANY_ROWS等,也可以自定义异常。 9. **客户端开发工具** Oracle提供SQL Developer这样的免费工具,以及更专业的Toad和SQL*Plus。这些工具支持编写、调试、测试和管理PL/SQL代码...
{12.13.1}insert}{175}{subsection.12.13.1} {12.13.2}create}{175}{subsection.12.13.2} {12.13.3}rownum}{175}{subsection.12.13.3} {12.13.4}update}{176}{subsection.12.13.4} {12.13.5}delete}{177}{...