`
kongzimengsheng1
  • 浏览: 70286 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

转 jdbc oracle many data insert

    博客分类:
  • java
阅读更多

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 + 批处理)性能更优。

分享到:
评论

相关推荐

    oracle-电子书资料

    预定义的异常如NO_DATA_FOUND和 TOO_MANY_ROWS,以及自定义异常,都能帮助编写健壮的PL/SQL代码。 8. **表单和触发器**:PL/SQL可以创建表单和触发器,表单用于用户交互,触发器则在特定数据库事件(如INSERT、...

    PLSQL.rar_oracle

    `EXCEPTION`关键字用于定义异常处理部分,常见的内置异常有`NO_DATA_FOUND`(未找到数据)、`TOO_MANY_ROWS`(返回过多行)和`OTHERS`(所有未明确捕获的异常)。 5. **游标**:游标允许PLSQL程序逐行处理查询结果...

    精通oracle.10g.pl.sql编程

    7. **异常处理**:熟悉如何使用EXCEPTION块来捕获和处理运行时错误,如NO_DATA_FOUND、TOO_MANY_ROWS等。 8. **包(PACKAGE)**:了解包的概念,它是将相关的常量、变量、过程和函数组织在一起的方式,提高代码的...

    plsql高级应用以及开发

    例如,使用NOTFOUND、NO_DATA_FOUND、TOO_MANY_ROWS等预定义异常来处理特定错误。 5. **游标**:游标允许程序逐行处理查询结果,是PL/SQL中处理大量数据的重要工具。它们可以与循环结合,实现对结果集的迭代操作。 ...

    plsql develop

    预定义的异常如NO_DATA_FOUND、TOO_MANY_ROWS等,也可以自定义异常。 9. **客户端开发工具** Oracle提供SQL Developer这样的免费工具,以及更专业的Toad和SQL*Plus。这些工具支持编写、调试、测试和管理PL/SQL代码...

    Java学习笔记-个人整理的

    {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}{...

Global site tag (gtag.js) - Google Analytics