oracle中的lob定位符,ORA-22990: LOB 定位符无法扩展事务处理

01fac6460a22031b8af8da5848698a70.png

关于JDBC驱动的版本,您可以参考以下文档:

How To Determine The Exact JDBC Driver Version (9.x – 11.x) For Standalone Programs [ID 467804.1]

另外请您参考以下文档,该文档介绍了一种导致JDBC程序报告ORA-22990错误的场景:

ORA-22990: LOB Locators Cannot Span Transactions ( Doc ID 113666.1 )

The Oracle oracle.sql.BLOB OutputStream writes the data in chunks. Since autocommit defaults to true, the first chunk is committed. This results in the write operation for the next chunk of the Blob to fail since it appears to be in the next transaction.

In those conditions, the ORA-22990 exception will occur with any version of Oracle JDBC driver.

Oracle oracle.sql.BLOB OutputStream对象以分块(chunk)的方式写数据。因为autocommit参数默认是true,如果第一个chunk提交,会导致写下一个chunk失败,因为该操作已经走到了下一个事务。这种情况下JDBC驱动会报告ORA-2290。

该问题的解决方法是,在connection中开始设置setAutoCommit为false。在所有的chunck都写完后,最后调用stream.close()来进行提交。

您的代码中使用的是Clob,但是该文档也可能适用。您可以参考文档修改您的代码,在执行sql之前调用conn.setAutoCommit(false), 然后在数据全部完成之后调用writer.close()。

为了能继续分析此问题,请您提供以下信息:

1. JDBC驱动的具体版本,请您参考之前我们提供的文档检查JDBC驱动的版本。

2. ORA-22990发生的原因是由于transaction发生了变化。在另外一个文档中记录了由于在在事务进行过程中,物理连接的变化导致的ORA-22990。

在整个transaction开始到commit期间,jdbc使用的物理连接是不能变的。如果您使用了连接池,请您检查连接池是否有可能在事务执行期间更换物理连接。

例如WebLogic Server的连接池提供了KeepXAConnTillTxComplete参数来保证XA Transaction从始至终使用同一物理连接,来避免该问题。

Oracle是当今各领域应用比较广泛的一个大型关系型数据库产品,它以其所拥有的稳定、可伸缩性强以及安全可靠等特性受到越来越多的系统开发人员的青睐,正成为企业开发信息系统的首选产品。同其他数据库管理系统相比,Oracle产品较为庞大而复杂,因此,令许多数据库管理系统的学习者在Oracle面前止步不前,究其原因,主要是无法掌握Oracle技术的脉络。本书正是根据作者在高校和各种数据库培训班执教多年的教学经验,结合开发应用Oracle数据库的实践经验编撰而成的,书编排的内容次序非常适合于读者学习和把握Oracle的脉络,书所选择的问题都是在实际开发应用Oracle过程经常遇到和所要解决的。通过学习解决这些问题的方法,可以使读者比较深入地认识和掌握Oracle技术的内涵,快速地进入开发角色。本书共分11章。第1章Oracle的安装卸载与使用环境,主要包括Oracle安装环境及方法,安装后的基本环境及服务,Oracle卸载,还包括验证数据库的安装,系统临时空间不足、监听服务无法启动以及Oracle默认帐户/口令等问题的精讲。第2章 Oracle体系结构,包括Oracle数据库逻辑结构和数据库物理结构以及Oracle文件的目录结构等。在案例精讲对数据块校验、表的移动、数据文件丢失或损坏、丢失控制文件、数据文件更名以及数据库内文件的复制传输等问题的解决做了全面细致的讲解。第3章SQL及PL/SQL的运行环境及其他开发工具。第4章 Oracle数据字典管理与数据类型。包括数据字典的分类、使用方法以及各种对象的具体查询等做了详细的介绍。第5章 数据库对象的创建与使用。主要包括各种类型的表创建以及适用情形,如外部表、分区表、嵌套表、全局临时表等;完整性约束的管理;索引,包括B树索引、基于函数的索引、位图索引、反向索引、降序索引、压缩索引等的使用方法及其适用情形等。在案例精讲,对表压缩、约束的使能与失能、表的层次结构查询、防止删除表及对象、提取创建外键约束的脚本以及在线重新定义表结构的方法做了详细讲解。第6章 PL/SQL程序设计。介绍了PL/SQL常用的函数、异常处理等,还有对随机数生成、分析函数、多表合并、多表插入等问题的解决方法。第7章 子程序和触发器,包括函数、存储过程、包以及触发器等。对子程序的调用者权限、管道表函数、传递触发器标识:new和:old以及自治事务也给出了具体的解决方法。第8 章 LOB与面向对象的数据管理. 第9章 Oracle的监听器和网络设置。包括Oracle网络体系结构,Oracle Net参数文件的管理,监听器与网络连接配置等。针对应用经常出现问题,如保护与设置监听器,监听器远程管理,端口号,客户机与服务器的连接,外部过程调用,不能解析服务名以及没有监听器等都给出了详细的解决方法。第10章 数据库管理,包括导出数据库模式的DDL脚本,管理Oracle数据库实例的方法、数据恢复与Flashback以及更改数据库字集等具体方法。第11章 数据库的安全管理。包括加密Oracle子程序,存储应用程序用户名和口令,禁止修改删除数据库对象,Oracle数据加密以及丢失SYSMAN及资料档案库用户口令的解决方法。书给出了丰富的图表,多数图例是作者根据多年实践总结出来的,图示简练准确,易于理解,并附有解决问题的具体步骤方法和相应的脚本。读者对象:面向各种培训班学员,高校相关专业的学生, Oracle应用开发人员以及Oracle数据库的学习者。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值