java经验总结二:ORA-08103: 对象不再存在
问题发生的环境: 在springMvc+mybatis框架中,调用oracle的存储过程时,碰到的一个这样的异常:
org.springframework.jdbc.UncategorizedSQLException:
### Error querying database. Cause: java.sql.SQLException: ORA-: 对象不再存在
### The error may exist in com/coscon/wechat/oracle/mapper/VgmCntrMapper.xml
### The error may involve com.coscon.wechat.oracle.mapper.VgmCntrMapper.findVgmInfoByBkgNo
### The error occurred while handling results
### SQL: {call SP_VGM_CNTR_QUERY(?, ?, ?, ? ) }
### Cause: java.sql.SQLException: ORA-: 对象不再存在
; uncategorized SQLException ]; error code []; ORA-: 对象不再存在
; nested exception : 对象不再存在
问题的原因
调用的oracle存储过程【sp】中,存在一个事物级别的临时表,例如:
create global temporary table TEMP_VGM_CNTR ( vgm_uuid VARCHAR2(), cntr_num VARCHAR2(), cntr_type VARCHAR2(), bkg_num VARCHAR2(), bl_num VARCHAR2(), vgm_tare_wt NUMBER(,), vgm_wt NUMBER(,), vgm_wt_unit VARCHAR2(), excel_logs VARCHAR2() ) on commit delete rows;
事物级临时表,当发生事物提交的时候,临时表中的数据就会被清空。
对于返回游标的存储过程来说,放在临时表中的数据就会被清空。那么在Java代码去调用存储过程时候,如果没有特殊的事物配置,在调用完存储过程后,就代表事物的结束,数据自然就没有了。so,程序就产生了“ORA-08103: 对象不再存在”的异常。
问题的解决
在springMVC+mybatis的数据库配置中添加事物处理机制:
<bean id="oracleTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <!--代表数据库环境:oracle-->
<property name="dataSource" ref="oracleDataSource" />
<qualifier value="ebTransactionManager"/>
<!-- <property name="typeAliasesPackage" value="com.coscon.wechat.oracle.entity" /> -->
</bean>
<bean id="oracleSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!---具体数据库配置-->
<property name="dataSource" ref="oracleDataSource" />
</bean>
<!-- 可通过注解控制事务,即事物处理的机制 -->
<tx:annotation-driven transaction-manager="oracleTransactionManager"/>
<!-- Mapper接口所在包名,Spring会自动查找其下的Mapper -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="sqlSessionFactoryBeanName" value="oracleSessionFactory"/>
<property name="basePackage" value="com.coscon.wechat.oracle.mapper" />
</bean>
注意:
由于项目中会出现配置了多个数据源的情况,注解事务时显示指明事务由谁管理。例如:
<qualifier value="ebTransactionManager"/>
然后在你调用的方法的service层,添加事物注解:
@Override
@SuppressWarnings("unchecked")
@Transactional(value = "ebTransactionManager",propagation= Propagation.REQUIRED)
public List<VgmCntr> findVgmInfoByBkgNo(String bkgNum, String blNum,
String cntrNum) {
Map<String, Object> map=new HashMap<String, Object>();
map.put("bkgNum", bkgNum);
map.put("blNum", null);
map.put("cntrNum", null);
vgmCntrMapper.findVgmInfoByBkgNo(map);
List<VgmCntr> list=(List<VgmCntr>)map.get("rows");
return list;
}
java经验总结二:ORA-08103: 对象不再存在的更多相关文章
- 乐字节Java反射之二:实例化对象、接口与父类、修饰符和属性
大家好,小乐继续接着上集:乐字节Java反射之一:反射概念与获取反射源头Class 这次是之二:实例化对象.接口与父类.修饰符和属性 一:实例化对象 之前我们讲解过创建对象的方式,有new .克隆.反 ...
- 系统学习 Java IO (十二)----数据流和对象流
目录:系统学习 Java IO---- 目录,概览 DataInputStream/DataOutputStream 允许应用程序以与机器无关方式从底层输入流中读取基本 Java 数据类型. 要想使用 ...
- Java基础 之二 类和对象
1.基础概念 1) 概念 简单来说,类是具有相同特征事物的抽象,比如有轮子的都可以抽象为车:对象则可以看做类的具体实例,比如创建一个法拉利的车,就是车这个类的实例. 抽象.封装.继承.多态是类的四个特 ...
- java多线程系列(二)---对象变量并发访问
对象变量的并发访问 前言:本系列将从零开始讲解java多线程相关的技术,内容参考于<java多线程核心技术>与<java并发编程实战>等相关资料,希望站在巨人的肩膀上,再通过我 ...
- java web学习总结(七) -------------------HttpServletResponse对象(一)
Web服务器收到客户端的http请求,会针对每一次请求,分别创建一个用于代表请求的request对象.和代表响应的response对象.request和response对象即然代表请求和响应,那我们要 ...
- Java设计模式(二) 工厂方法模式
本文介绍了工厂方法模式的概念,优缺点,实现方式,UML类图,并介绍了工厂方法(未)遵循的OOP原则 原创文章.同步自作者个人博客 http://www.jasongj.com/design_patte ...
- Java实验报告二:Java面向对象程序设计
Java实验报告二:Java面向对象程序设计 ...
- java 获取数组(二维数组)长度实例程序
我们可能知道 js有个length函数,java也有啊length函数 例 如果数组是data[],则data.length 代码如下 复制代码 byte[] phone =new byte[81]; ...
- java web 学习七(HttpServletResponse对象1)
Web服务器收到客户端的http请求,会针对每一次请求,分别创建一个用于代表请求的request对象.和代表响应的response对象.request和response对象即然代表请求和响应,那我们要 ...
随机推荐
- FZU 2122 又见LKity
直接模拟或者KMP #include <iostream> #include <string.h> #include <stdio.h> #include < ...
- 搭建Windows Azure开发环境-Azure虚拟机
概念 这一节是关于让设置了Azure的虚拟机,它包括的Visual Studio 2013 RC旗舰版和SQL Server 2012 Express的 . 在此动手实验中,您将探索建立使用Windo ...
- Java 并发之线程安全
写线程安全的代码,说白了就是管理一个类的共享的.可变的状态.只要有多于 1 个线程对类的状态进行写入,那么就必须用同步来协调这多个线程对状态的访问.对于一个没有状态的类来说(简单的理解就是只有方法没有 ...
- 算法导论学习-RED-BLACK TREE
1. 红黑树(RED-BLACK TREE)引言: ------------------------------------- 红黑树(RBT)可以说是binary-search tree的非严格的平 ...
- mysql-no-install 手动安装
D:\mysql-5.5.28-win32 1.下载mysql-5.5.15-win32.zip,解压到本地D:\mysql. 2.将my-small.ini另存为my.ini .(根据情况可以选择别 ...
- Mysql常见问题及优化
本文将就以下三个问题进行展开: 1.库表设计 2.慢 SQL 问题 3.误操作.程序 bug 时怎么办 一.库表设计 1.1 引擎选择 在 mysql 5.1 中,引入了新的插件式存储引擎体系结构,允 ...
- BZOJ 3280: 小R的烦恼 & BZOJ 1221: [HNOI2001] 软件开发
3280: 小R的烦恼 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 399 Solved: 200[Submit][Status][Discuss ...
- Unity手游之路<六>游戏摇杆之Easy Touch 3教程
之前已经介绍过Unity自带的摇杆Joystick,它用起来很简单.但是它也存在很多局限,不能全部满足普通mmo手游的一些需求,例如:要能方便地更好素材:能指定在某个区域显示,或者只有在该区域触摸时才 ...
- C# .Net基础知识点解答
原文地址 1. 什么是.NET?什么是CLI?什么是CLR?IL是什么?JIT是什么,它是如何工作的?GC是什么,简述一下GC的工作方式? 通俗的讲,.Net是微软开发应用程序的一个平台: CLI是C ...
- Runtime 函数 Swizzling 改变OC方法的调度顺序
首先加入一个小知识: SEL.Method.IMP的含义及区别 在运行时,类(Class)维护了一个消息分发列表来解决消息的正确发送.每一个消息列表的入口是一个方法(Method),这个方法映射了一对 ...