Oracle大量数据插入之性能优化理解Oracle认证考试

文章作者 100test 发表时间 2009:11:11 16:39:14
来源 100Test.Com百考试题网


"mkhgigh">

  在学习Oracle中,我们使用SQL和ODBC链接进行数据插入,单独插入少量数据时,没有问题。但是在插入大量数据时,就会出现异常,内存溢出错误。

  如何解决在进行大量数据插入时,java程序能够有效快速的进行数据处理。这就是数据库中性能优化的问题。

  为什么要进行性能优化。

  首先,在大量数据处理中 一般常规的方式会造成程序处理效率和时间低下。达不到产品上线要求。

  其次,没有性能优化在产品维护时也会出现很多错误,带来麻烦。

  如何进行性能优化。来源:考

  一般软件都会进行大量数据测试,对性能做个整体评估,然后找出最好的方法来编写需要的代码。

  同时再次进行测试达到最佳的性能点。

  对于Oracle大量数据插入的性能优化我们采用如下方法进行

  先采用常规方式编写代码,如在放入数据时就直接使用list接口方法进行。

  插入数据中不进行批处理使用。

  发现,在插入10万数据中 内存溢出,而且数据库使用时间非常长。

  于是,我们先采用数据库批处理命令 采用每1000条数据再进行一次提交

  使用addBAEACH 方法,和excutbeach 方法来处理

  代码为

  ps.addBatch().

  if(i!=0&.&.i000==0) {

  ps.executeBatch().

  con.commit().

  ps.clearBatch().

  }

  同时也使用预编译语句进行插入。

  但是在仍然不能解决虚拟机内存溢出问题

  于是我们使用

  String[] fileList = new File(uploadDir).list().

  ArrayList<.String[]>. array = new ArrayList<.String[]>.().

  array.clear().

  来解决读取文件后如何放入数据库中再使用SQL语句进行插入。

  经过反复测试。最后找到最优点。在插入100万数据情况下 每次1万条数据提交。性能最优。

  编辑特别推荐:

  110个oracle常用函数总结



相关文章


ORACLE索引聚簇表的数据加载Oracle认证考试
Oracle认证辅导:Oracle数据库体系架构概要Oracle认证考试
ibatis调用oracle的动态sqlOracle认证考试
深入浅出Oracle11g分区功能Oracle认证考试
Oracle大量数据插入之性能优化理解Oracle认证考试
oracle插入回车换行符Oracle认证考试
oracleimp_exp命令使用Oracle认证考试
oracle忘记用户名密码怎样恢复Oracle认证考试
Oracle中NUMBER类型问题Oracle认证考试
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛