Java OAF JDBC VARCHAR(2000) 字符大于2000

本文详细介绍了在使用OracleApplicationFramework(OAF)进行项目开发时,遇到字段长度过长导致数据库插入错误的问题,并提供了解决方案。通过重写EO中的buildDMLStatement方法,使得系统能够正确调用CallableStatement接口,从而解决字符过长导致的数据库插入问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在做OAF(Oracle Application Framework)项目的时候,发现一个问题,如果一个字段大于2000,在数据库插入的时候不会有问题,如果在页面插入(大于2000但没有超过这个字段的长度),OAF页面自带的验证不会报错,但是一提交到数据库就会报字符过长的问题。一般情况下,我们普通的SQL以“select、update”开头的SQL,在提交的时候会调 PreparedStatement这个接口的ps.setString()方法,这个方法对字符的的限制为2000,所以会有问题,如果是CallableStatement就没问题,给出一种解决方法,在EO里面重写buildDMLStatement方法,即,加上下面一段代码:
   protected StringBuffer buildDMLStatement(int operation,
AttributeDefImpl[] allAttrs,
AttributeDefImpl[] retCols,
AttributeDefImpl[] retKeys,
boolean batchMode)
{
StringBuffer result = super.buildDMLStatement(operation, allAttrs, retCols, retKeys, batchMode);
result.insert(0, "BEGIN ");
result.append("; END;");
return result;
}

这样就会调CallableStatement这个接口。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值