1、问:用JDBC访问ORACLE数据库,做DELETE操作,能用JAVA多线程实现吗? ORACLE服务器要怎么配?(以下答案来自网络,仅供参考)

答: Oracle有自己的锁机制。就算你开100条线,它还是一条一条删除。不能同时删除多项的。
     对于大量数据更新,Oracle有建议一些优化措施。
     (1) 首先是把auto-commit给关闭。因为你每删一条数据,oracle就要自动执行一次commit。commit是需要资源的。所以如果你手动设置为每删数据1000条,执行一次commit. 那你就可以节省资源了。
     (2) 充分利用batch update。如果不用batch,每个delete命令都需要从网络上传送到oracle。1万个删除命令,要有1万次传送。如果将100个删除命令绑在一起送去Oracle执行。那就只要传送100次就可以了。大大缩短所需时间和网络资源。
     以上这些建议,都可以在Oracle参考里查到。

2、问:oracle中什么操作需要commit才能保存到数据库?(以下答案来自网络,仅供参考)

答:平时用的时候Commit、Rollback 主要用在DML(数据操纵语言) - Insert、Update、Delete 这些语句上,可以设置保存点,然后依次提交,同样也可以rollback。单独commit,是把之前的数据改动都一次提交。正常的关闭,exit是可以自动提交的,可以不用commit,直接关闭窗口,属于强制关闭,关闭之前需要commit。

3、问:jdbc 批处理插入数据库 每100条提交一次,有余数时如何解决?(以下答案来自网络,仅供参考)

答:

String sql="insert into t1(id) values (?)";
Connection con=null;
PreparedStatement ps=null;

con= dao.getConnection();
ps=con.prepareStatement(sql);

ps.addBatch();


if(i%100==0)//每100条提交一次
{
ps.executeBatch();
con.commit();
ps.clearBatch();
}
改成
if(i%100==0||i==(list.size()-1)){
ps.executeBatch();
con.commit();
ps.clearBatch();
}

4、通过测试得到的:(来自网络,仅供参考)

(1)、批处理要conn.setAutoCommit(false)(默认会自动提交,不能达到批处理的目的,速度极慢!)。
     (2)、pstmt.executeBatch();    //PreparedStatement pstmt
                conn.commit();
        要提交,数据库才会有数据。
     (3)、避免内存溢出,应每x(如:万)条提交一次数据。
     (4)、可用“数据库名.表名”的方法来访问数据库表
        这样,则在写JdbcUtil的DB_CONNECTION = "jdbc:mysql://localhost:3306/"时,
        可不具体到数据库,方便跨数据库的数据操作。
     (5)、Statement和PrepareStatement不仅可以操作DDL,添加删除表和数据库的sql都可以操作,用execute(String sql)方法。

5、conn.setAutoCommit(true)和(false)的区别:(来自网络,仅供参考)

JDBC中的这个参数

true:sql命令的提交(commit)由驱动程序负责
false:sql命令的提交由应用程序负责,程序必须调用commit或者rollback方法

通过jdbc对数据库进行操作的时候,conn.commit(),可以将修改的数据提交,但是前提必须是数据库的autocommit属性为false,否则你进行一次操作后,数据库会自行commit。
6、为什么采用批处理的方式后,没有写conn.commit()也能提交?
答:这样可能是程序结束conn关闭导致的提交 conn.setAutoCommit(true)是控制是否每条SQL执行完后自动提交。

7、(一)
1.java程序循环执行10000条sql语句,不commit,共耗时13.395s;sql*plus可以查询的到;重启sql*plus

依然可以查询得到。
2.在sql*plus中执行删除表中内容 delete from "TAB_orderDetail"(没有commit);然后再在此次的

sql*plus中查询,记录数为0;但用java查询数据并没有被删除,还能查得到。但重启sql*plus,记录数仍

为10000。这都是由于在sql*plus中执行删除表中内容时没有commit造成的。
3.在java中执行删除表中内容 delete from "TAB_orderDetail"(没有commit),在java中再查询结果为0

;在sql*plus中查询结果也为0.(说明此时已经真正删除)
(二)
1、java程序循环执行10000条插入sql语句,不commit,共耗时7.652s。java程序循环执行10000条sql语句

,commit,共耗时7.595s。改为批处理后,批处理插入100000条记录,用时52.867s;批处理插入10000条记录,用时5.337s。

 

用JDBC访问ORACLE数据库 关于commit 增快效率 大数据 等的整理的更多相关文章

  1. JDBC连接Oracle数据库的问题

    场景:最近做一个java web项目,使用jdbc连接Oracle数据库,遇到了两个问题. 问题1:jdbc连接不上Ubuntu Oracle服务器? 后来发现这个问题的原因是由于连接字符串写错了,修 ...

  2. 【方法】如何限定IP访问Oracle数据库

    [方法]如何限定IP访问Oracle数据库 1.1  BLOG文档结构图 1.2  前言部分 1.2.1  导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知 ...

  3. JAVA通过JDBC连接Oracle数据库详解【转载】

    JAVA通过JDBC连接Oracle数据库详解 (2011-03-15 00:10:03) 转载▼http://blog.sina.com.cn/s/blog_61da86dd0100q27w.htm ...

  4. .net(C#)访问Oracle数据库的几种免安装组件的对比

    Oracle 数据存取组件(ODAC) 库为Borland Delphi,C++ Builder 以及 Kylix提供了一些非可视化的组件.它们用来存取Oracle关系数据库系统.与BDE类似, OD ...

  5. jdbc连接oracle数据库

    /*** 通过改变配置文件来连接不同数据库*/package com.xykj.jdbc; import static org.junit.Assert.*; import java.io.Input ...

  6. .net(C#)访问Oracle数据库的几种免安装组件的对比(转)

    原文地址 [内容为转载,个人推荐还是用官方的组件,推荐使用 Oracle.DataAccess.dll ] .net(C#)编程过程中,使用到了以下三种免安装的Oracle访问组件,能够不安装Orac ...

  7. 运行于64操作系统上的C#客户端通过WCF访问Oracle数据库不兼容问题

    运行平台: Windows 7  64位操作系统 运行环境: IIS 7 编程语言:C# 数据库: 32位的Oracle 10g 运行原因:64位操作系统C#客户端程序通过WCF访问ORACLE数据库 ...

  8. 在Eclipse中使用JDBC访问MySQL数据库的配置方法

    在Eclipse中使用JDBC访问MySQL数据库的配置方法 分类: DATABASE 数据结构与算法2009-10-10 16:37 5313人阅读 评论(10) 收藏 举报 jdbcmysql数据 ...

  9. ODP.NET 之访问 Oracle 数据库

    ODP.NET 之访问 Oracle 数据库 要相使用 Oracle Data Provider For .NET(ODP.NET), 必须先安装 ODP.NET 或者是 ODAC(Oracle Da ...

随机推荐

  1. Web 高性能开发汇总

    1. Http服务器: 让Windows Server 2008+IIS 7+ASP.NET支持10万个同时请求 大规模网站架构实战之体系结构(一) 大规模网站架构之WEB加速器SQUID(二) ii ...

  2. 子查询优化成join关联查询时要注意一对多关系

    mysql> select * from t where t.id in (select t1.tid from t1); +------+ | id | +------+ | +------+ ...

  3. Js 处理将时间转换 “年-月-日”

    将时间  \/Date(1432828800000+0800)\/"  转换成:“年-月-日” //时间转换function ChangeDateFormat(val) {    if (v ...

  4. IOS成长之路-调用照相机和相册功能(转)

    转载自:http://blog.csdn.net/like7xiaoben/article/details/8465237 //先设定sourceType为相机,然后判断相机是否可用(ipod)没相机 ...

  5. 制作输入框(Input)

    怎样判断是否应当使用输入框 输入框,就是用户可以自由输入文本的地方.当需要判断是否需要使用输入框时,可以遵循一条原则:凡是需要用户自主输入文本的地方,几乎都必须使用输入框. 输入框的常见用法:输入登录 ...

  6. html template

    https://wrapbootstrap.com/tag/single-page http://themeforest.net/ https://wrapbootstrap.com/themes h ...

  7. jsf2.0视频

    jsf2.0 入门视频 教程   需要的看下.初次录视频.还有很多需要完善. JSF交流QQ群84376982 JSF入门视频下载地址  http://pan.baidu.com/s/1jG3y4T4 ...

  8. centos7初步配置

    centos7初步配置 首先安装lrzsz zip/unzip yum -y install lrzsz yum -y install zip unzip 安装vim yum install vim* ...

  9. C#学习笔记---基础入门(二)

    枚举 枚举是被命名的整型常数的集合:枚举类型的变量只有赋值后才能使用:不同枚举中的枚举值可以重名:可以自定义枚举值. enum Playstates {            跑, 跳,下滑,左转,右 ...

  10. Linux下反斜杠号"\"引发的思考

    今天在检查home目录时发现有一个名为“\”的文件,觉得很奇怪,从来没见过,就准备用Vim打开看看,很自然地输入命令查看一下,结果居然打不开. ubuntu@ubuntu:~$ vi \> ub ...