oracle 一个char类型列,将Java Character对象值插入Oracle CHAR(1)列时出错

我正在使用

Spring jdbcTemplate.update(String sql,Object [] args)在Oracle数据库上执行准备好的insert语句.其中一个对象是包含值“Y”的Character对象,目标列是CHAR(1)类型,但我收到的是

java.sql.SQLException: Invalid column type

例外.

我已经调试了这个向后和向前,毫无疑问,这是导致问题的一个特定对象.当省略此字符对象时,插入将按预期执行.

我还可以输出sql和Object []值,将sql复制到sql developer中,将值占位符(?s)替换为Objects的实际值,插入将正常工作.

sql(混淆保护有罪):

INSERT INTO SCHEMA.TABLE(NUMBER_COLUMN,VARCHAR_COLUMN,DATE_COLUMN,CHAR_COLUMN) VALUES (?,?,?,?);

对象值:

values[0] = [123]

values[1] = [Some String]

values[2] = [2012-04-19]

values[3] = [Y]

该组合在sql developer中手动运行,并且运行正常:

INSERT INTO SCHEMA.TABLE(NUMBER_COLUMN,VARCHAR_COLUMN,DATE_COLUMN,CHAR_COLUMN) VALUES (123,'Some String','19-Apr-2012','Y');

准备好的语句sql本身是根据数据传输对象中包含的非空实例变量对象动态生成的(我们希望数据库处理默认值的生成),所以我不能接受任何答案,这表明我只是在重做sql或插入例程.

任何人都遇到过这种情况,可以向我解释发生了什么以及如何解决这个问题?令人沮丧的是,我似乎无法将一个Character对象插入CHAR(1)字段.任何帮助将非常感激.

真诚的,长期潜伏的第一次海报

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值