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>


网上查了不少文章,试了好几种方法,都是因为长度导致失败。特到这儿发帖求助,望大家帮忙看看怎么解决。
...全文
504 11 打赏 收藏 转发到动态 举报
写回复
用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!

67,542

社区成员

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

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