忘记commit的一次教训
由于业务需求,已经上线的系统新增加了一些需求,其中一个需求是,从一个SQLSERVER数据库导入数据到生产的ORCLE数据库,
由于我的失误导致系统上线后 生产的Oracle数据没有导入成功,但是在本地测试的时候是正常的,其中有一点要说明就是系统采用的是
jdbc方式操作数据库,数据库连接使用的是连接池的方式。我懒省事,本地就没有配置连接池,直接用jdbc进行的连接,因为要导入数
据的oracle中,操作的时候就要采用分批提交的方式,所以要将事务设置成手动提交,conn.setAutoCommit(false);这就给我的失误埋下了炸弹。
下面就记录下处理这个失误的整个过程:
系统再次上线后,客户反映说数据没有导入,于是我就远程上他们的数据库,结果发现新添加的几个表的确没有数据,这时十分惊讶,
感觉不太可能,于是又给客户他们要了上线后的日志,看后日志发现没有报任何错误,而且导入的步骤日志显示导入也都顺利执行了,
这时我就更加奇怪了,但是既然出现问题了,作为苦逼的程序员就要解决问题啊。于是又重新check了一下代码,当我看到
conn.setAutoCommit(false);的时候眼睛亮了,于是继续往下走,发现自己忘记了commit,心里大大松了一口气,但是另一个问题又出来了,
为什么我本地采用jdbc直接连接的时候数据可以插入进去,加不加commit没有影响呢?难道错误不在这里?为了和生产上环境一致,
我决定采用数据库连接池的方式重新测试一下,由于服务器采用的是jboss4.0,以前没有配置过,所以又搜索了一下配置方法,下面也记录一下吧
1.Copy数据库的JDBC驱动至部署文件夹中的lib目录下
2. 建立数据库配置文件,配置数据库参数,文件以-ds.xml为结尾,如oracle-ds.xml。配置文件具体方法参照docs/example/jca下,有各种数据库的例程。
你可以针对自己的来写,如下:
<datasources>
<local-tx-datasource>
<jndi-name>jdbc/ews</jndi-name>
<connection-url>jdbc:oracle:thin:@192.168.4.222:1521:orcl</connection-url>
<driver-class>oracle.jdbc.OracleDriver</driver-class>
<user-name>ewsvii</user-name>
<password>ewsvii</password>
<min-pool-size>5</min-pool-size>
<max-pool-size>50</max-pool-size>
<blocking-timeout-millis>60000</blocking-timeout-millis>
<idle-timeout-minutes>2</idle-timeout-minutes>
<exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.OracleExceptionSorter</exception-sorter-class-name>
</local-tx-datasource>
</datasources>
web应用为default,则放在$JBOSS4_HOME\server\default\deploy下。
配置完数据库连接池后,然后分别在使用commit和不使用commit的时候进行测试,结果发现这时候如果不使用commit数据就无法插入成功。
这样也就找到了问题的所在,修改了代码之后重新上线,oracle数据就可以正常导入了。
但是为什么采用jdbc直接连接数据库的时候,不使用commit的话数据可以正常插入呢?这个问题还是没有解决。
忘记commit的一次教训的更多相关文章
- 为什么忘记commit也会造成select查询的性能问题
今天遇到一个很有意思的问题,一个开发人员反馈在测试服务器ORACLE数据库执行的一条简单SQL语句非常缓慢,他写的一个SQL没有返回任何数据,但是耗费了几分钟的时间.让我检查分析一下原因,分析解决过后 ...
- 忘记commit也会造成select查询的性能问题
今天遇到一个很有意思的问题,一个开发人员反馈在测试服务器ORACLE数据库执行的一条简单SQL语句非常缓慢,他写的一个SQL没有返回任何数据,但是耗费了几分钟的时间.让我检查分析一下原因,分析解决过后 ...
- 数据库commit问题
对数据库进行修改后,需要commit!---之前也是忘记commit导致数据库反应不过来.
- Git(远程仓库:git@oschina)-V2.0
1.注册git@osc(也就是“码云”) 这里会提示注册密码==push密码,反正一定要记住的东西. 2.安装git 这里要设置个人信息 git config --list //查看git信息 g ...
- Oracle 行转列,列转行
一.行转列1.1.初始测试数据表结构:TEST_TB_GRADESql代码:1 create table TEST_TB_GRADE2 (3 ID NUMBER(1 ...
- Android SharePreference 在主进程和次进程间共享数据不同步出错
SharedPreference作为android五大存储(网络,数据库,文件,SharedPreference,contentProvider)之中最方便使用的一个,从类名上来看就不是一个存储大 ...
- DB2解除锁表
背景 生产环境中,我几乎没有遇到过锁表.多是在开发过程中遇到的,比如团队开发中经常会遇到多个功能访问同一张表的情况.如果有开发人员在这张表加了排它锁,然后又忘记提交事务,那么其他开发人员就要一直等待了 ...
- androidactivity与webview结合
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android=" ...
- a different object with the same identifier value was already associat
问题:这个著名的托管态update更新异常 org.hibernate.NonUniqueObjectException: a different object with the same ident ...
随机推荐
- php文件上传限制
PHP默认的上传限定是最大2M,想上传超过此设定的文件,需要调整PHP.apache等的一些参数.下面,我们简要介绍一下PHP文件上传涉及到的一些参数: file_uploads :是否允许通过HTT ...
- items 与iteritems
dict的items函数返回的是键值对的元组的列表,而iteritems使用的是键值对的generator. items当使用时会调用整个列表 iteritems当使用时只会调用值. >> ...
- linux process 相关命令
1.显示指定用户信息:ps -u root 2.显示所有进程信息,连同命令行:ps -ef 3. ps 与grep 常用组合用法,查找特定进程:ps -ef|grep ssh 4. 把所有进程显示出来 ...
- mybatis学习(一)一个在idea下的实例
今天总结的是mybatis,首先说mybatis是什么? MyBatis 是一个简化和实现了 Java 数据持久化层(persistence layer)的开源框架,它抽象了大量的 JDBC 冗余代 ...
- 【nodemailer】之 work with mustache
之前对nodemailer做了简要的研究,基本上是搞定了发邮件的问题.但很多情况下邮件的内容不是固定的,然后又需要有一个合适的样式,这就需要使用模板了.nodemailer有nodemailer-ma ...
- angular中的orderBy过滤器使用
一 orderBy过滤器 AngularJS中orderBy进行排序,第一个参数可以有三种类型,分别为:function,string,array: 第一种:function,如果是func ...
- MySQL企业常用集群图解
mysql集群架构图片 1.mysql企业常用集群架构 在中小型互联网的企业中.mysql的集群一般就是上图的架构.WEB节点读取数据库的时候读取dbproxy服务器.dbproxy服务器通过对S ...
- hibernate查询显示参数
log4j.property改为如下 ### direct log messages to stdout ### log4j.appender.stdout=org.apache.l ...
- Linux性能监控的几个工具(转)
转载于:http://blog.csdn.net/tianlesoftware/article/details/6198780 Linux系能监控主要涉及系统4个方面资源的监控: CPU Memory ...
- 关于aspx模板页面元素路径的问题,以及对模板页面的理解
模板页面仅是模板,它不是单独存在的页面,它的路径就是引用它的内容页面的路径. 换句话说,模板页面,只是内容页面上固定的部分. 模板页面引用了的js和CSS,内容页面就不用重新引用了 css ...