sprintmvc+ibatis+oracle无法插入clob字段的问题

soyestrellafortuna 2015-03-04 06:06:10
客户提供的代码框架
其中使用的有:ibatis-2.3.4.726.jar、ojdbc6.jar、classes12.jar
问题描述如下
当请求第三方做交易操作时,第三方会将交易的报文返回,我需要将请求的报文与返回的报文保存到表中。当报文较少的时候,能正常插入。但当报文比较大的时候,则无法进行插入操作。
异常信息如下
17:28:54,733 INFO  [XmlBeanDefinitionReader] Loading XML bean definitions from class path resource [org/springframework/jdbc/support/sql-error-codes.xml]
17:28:54,906 INFO [SQLErrorCodesFactory] SQLErrorCodes loaded: [DB2, Derby, H2, HSQL, Informix, MS-SQL, MySQL, Oracle, PostgreSQL, Sybase]
17:29:07,084 ERROR [STDERR] org.springframework.jdbc.UncategorizedSQLException: SqlMapClient operation; uncategorized SQLException for SQL []; SQL state [null]; error code [17070];
--- The error occurred in com/upic/pay/biz/bo/sql/TradeMessagesSql.xml.
--- The error occurred while applying a parameter map.
--- Check the tradeMessages.insert-InlineParameterMap.
--- Check the parameter mapping for the 'requestXml' property.
--- Cause: java.sql.SQLException: 数据大小超出此类型的最大值: 3539; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException:
--- The error occurred in com/upic/pay/biz/bo/sql/TradeMessagesSql.xml.
--- The error occurred while applying a parameter map.
--- Check the tradeMessages.insert-InlineParameterMap.
--- Check the parameter mapping for the 'requestXml' property.
--- Cause: java.sql.SQLException: 数据大小超出此类型的最大值: 3539


环境大致描述如下:
oracle中有一张交易报文的表,其中包括请求与返回两个字段是clob类型。存放XML类型的数据。
主要的字段如下

BIZ_NO = #bizNo:VARCHAR#,
SERIALIZE_NO = #serializeNo:VARCHAR#,
RESPONSE_XML = #responseXml:CLOB#,
REQUEST_XML = #requestXml:CLOB#,
INTERACTIVE_TIME = #interactiveTime:DATE#,
INTERACTIVE_TYPE = #interactiveType:VARCHAR#,
CHANNEL_TYPE = #channelType:VARCHAR#,
TRADE_TYPE = #tradeType:VARCHAR#,

java对象主要属性如下:geter,seter方法略
	private String messageId;
private String bizNo;
private String serializeNo;
private String responseXml;
private String requestXml;
private Date interactiveTime;
private String interactiveType;
private String channelType;
private String tradeType;


ibatis的配置主要点如下
dao-context.xml
 
<bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
<property name="configLocation" value="com/upic/pay/biz/bo/sql/sql-map-config.xml" />
<property name="dataSource" ref="dataSource" />
<property name="lobHandler" ref="lobHandler" />
</bean>

<bean id="lobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler" lazy-init="true"/>

sql-map-config.xml

<sqlMapConfig>
<settings
cacheModelsEnabled="true"
enhancementEnabled="true"
lazyLoadingEnabled="true"
maxSessions="3000"
maxTransactions="3000"
maxRequests="3000"/>

<typeHandler jdbcType="CLOB" javaType="java.lang.String" callback="org.springframework.orm.ibatis.support.ClobStringTypeHandler" />
</sqlMapConfig>


插入部分的sql如下

<insert id="tradeMessages.insert" parameterClass="com.upic.pay.domain.TradeMessages">
<![CDATA[
insert into T_PAY_TRADE_MESSAGES
(
MESSAGE_ID,
BIZ_NO,
SERIALIZE_NO,
RESPONSE_XML,
REQUEST_XML,
INTERACTIVE_TIME,
INTERACTIVE_TYPE,
CHANNEL_TYPE,
TRADE_TYPE,
CREATED_BY,
CREATED_DATE,
UPDATED_BY,
UPDATED_DATE
,DELETED_FLAG
)
values
(
#messageId:VARCHAR#,
#bizNo:VARCHAR#,
#serializeNo:VARCHAR#,
#responseXml,javaType=java.lang.String,jdbcType=CLOB#,
#requestXml,javaType=java.lang.String,jdbcType=CLOB#,
#interactiveTime:DATE#,
#interactiveType:VARCHAR#,
#channelType:VARCHAR#,
#tradeType:VARCHAR#,
#createdBy:VARCHAR#,
sysdate,
#updatedBy:VARCHAR#,
sysdate
,'0'
)
]]>
</insert>


网上查了不少文章,试了好几种方法,都是因为长度导致失败。特到这儿发帖求助,望大家帮忙看看怎么解决。
...全文
495 11 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
scmod 2015-05-25
  • 打赏
  • 举报
回复
不明觉厉.... <bean id="lobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler" lazy-init="true"/> 这个的lazy-init是不是不大好...
jiangpin0801 2015-05-24
  • 打赏
  • 举报
回复
楼上的方法都可以试试。。不过我是代码小白,所以一般做报表都选finereport,毕竟可以实现零编码嘛,嘿嘿~
soyestrellafortuna 2015-03-06
  • 打赏
  • 举报
回复
测试了一下,还是没成功,再顶一下
xxb_zrx 2015-03-06
  • 打赏
  • 举报
回复
程序的字符串长度不等同于数据库的字段定义的限定只付出长度,GBK在数据库中一个字符占2个字节,而UTF-8占3个字节,所以程序输入的字符串与数据库字段限定长度应该是2-3倍的关系,如果还是无法解决,可以尝试使用setCharacterStream的方法对blob字段写入。
suciver 2015-03-06
  • 打赏
  • 举报
回复
你数据库的对应的字段类型是clob类型吗,oracle的clob数据长度能到4G不可能不够的
  • 打赏
  • 举报
回复
http://www.linuxidc.com/Linux/2013-06/86381.htm

我所看到的很多都是先置空对象,然后再填入
soyestrellafortuna 2015-03-05
  • 打赏
  • 举报
回复
谢谢楼上朋友给的建议,我先试试。 再顶一下,看看有没有其他的方法可供参考! PS:祝大家元宵节快乐
姜小白- 2015-03-05
  • 打赏
  • 举报
回复
大字段为流数据,对大字段的操作应该要单独来操作的 参考 Java对blob操作
soyestrellafortuna 2015-03-05
  • 打赏
  • 举报
回复
现在出现的问题总感觉是字段的长度受到限制
Cause: java.sql.SQLException: 数据大小超出此类型的最大值: 3539
照网上很多教程的方式做了调整,都是出现数据库字段长度超出的错误。是否是我解决问题的思路错误了。(并不是clob无法保存,而是字段长度限制?)
willis_326 2015-03-04
  • 打赏
  • 举报
回复
以前遇到过同样的问题,但使用的不是ibatis 当时解决方法是: 先插入一条记录, clob字段为空; 然后再读出该记录, 更新clob的值. 参考:http://blog.csdn.net/linwei_1029/article/details/6890749
soyestrellafortuna 2015-03-04
  • 打赏
  • 举报
回复
手误,springmvc写成了sprintmvc了,sorry!
dbking 0.6 ========== dbking是一款基于Java的数据库处理工具集,主要包括三项主要内容: 1、为各类数据库提供统一的操作接口,尽最大可能保障各类数据库之间的移植性 2、通过生成器创建BO类及DAO层代码 3、为各类数据库之间的数据导入导出提供高效率的工具 下面对这三项功能进行详细的介绍。 1、为各类数据库提供统一的操作接口,尽最大可能保障各类数据库之间的移植性   这类工具已经很多了,比如大家耳熟能详的Hibernate、iBatis,包括Apache的DBUtils、Spring的JdbcTemplate。为什么我们还要推出db-unifier这样一个功能类似的东西呢?   这些工具的主要目的都是对JDBC进行包装,使开发人员能更容易的进行数据库开发,在代码的可读性、性能问题、移植问题上,这些工具都尽量做了权衡,达到了他们认为的完美。   dbking是鉴于我们的开发经验和考虑,权衡出来的数据库工具,其主要考虑的方向有以下几点:   1、简洁。所有的核心接口都在一个类里边,这个类是DbKing,代码不过1000行,却提供了大量的高质量功能方法,使用方法更是一目了然的简单。DbKing核心只依赖于JDBC驱动类,十分的轻量级,易于使用。   2、避免数据库连接泄漏的问题。数据库建立连接、关闭连接默认情况下都由db-unifier处理。有人会觉得这样影响效率,当然我们也提供自己手动控制连接的方法,只是默认情况下采用自动的方式。   3、统一的数据库操作类型。在dbking中,所有的数据库数据只有五种数据类型,String、Number(BigDecimal)、Timestamp、Clob(String)、Blob(byte[]),经过反复测试后,我们会例出各种数据库数据类型到这五种类型的映射表,当然我们也有少数的数据类型不能支持,有些是JDBC驱动的问题,有些是我们出于移植的考虑,有些数据库的数据类型在别的数据库里没有对应的数据类型支持,这样的数据类型只能不予支持,幸好这只是极少的一部分。   4、简化了很多复杂的数据库操作。比如:数据库分页,你不用再关心记录总数怎么取,不用考虑各种数据库之间的差异,最关键的是绝对的高效。再比如LOB字段的处理,可以直接通过增、删、改、查等接口处理,遇到较大的LOB,也可以用流的方式处理,避免内存溢出的问题。再比如获取数据库序列,我们采用了统一的算法,不同的数据库都使用同一个接口来获取序列,而且这个方法可以在多线程环境下使用,甚至是集群环境下都没有问题。   5、提供多种使用方式。可以单独使用,也可以结合Spring IoC框架使用。可以通过配置方式指定数据源,也可以通过硬代码方式指定数据源,甚至通过第三方获取数据库连接的方式都是可以的。 目前工具在Oracle 11g、Microsoft SQLServer 2012、MySQL 5.x、DB2 10.x、Sybase 15.x、PostgreSQL 9.x、Derby 10.x上通过了测试。 2、通过生成器创建BO类及DAO层代码   这是一个配合dbking的代码生成器,生成基于dbking的DAO层类。有了这样类,可以简化开发代码,避免低级的书写错误,使开发者更专注于业务。另外,也可以在此基础上配合一定的代码来防止SQL注入的问题。 3、为各类数据库之间的数据导入导出提供高效率的工具   异构数据库的导入导出一直是个大难题,一般的工具配置复杂,尤其是不支持LOB这样的大字段数据,我们的这个工具不仅配置简单,而且具有以下几个特点。   1、速度非常快,这个因为取决于系统环境,这个只有谁用谁知道了,至少我们是跟别的工具作过比较的。   2、支持LOB字段的导入导出。   3、自动侦测数据库表的主、从关系,保障数据库的导入不受外键约束的影响。   4、根据配置可以选择遇到重复数据时的处理方式————忽略或者中止。

67,543

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧