我正在使用Spring jdbcTemplate.update(String sql,Object [] args)在Oracle数据库上执行准备好的insert语句.其中一个对象是包含值“Y”的Character对象,目标列是CHAR(1)类型,但我收到的是java.sql.SQLException: In...
我正在使用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)字段.任何帮助将非常感激.
真诚的,长期潜伏的第一次海报
解决方法:
没有PreparedStatement.setXxx()接受字符值,Oracle文档声明所有JDBC字符类型都映射到Java字符串.另请参见http://docs.oracle.com/javase/1.3/docs/guide/jdbc/getstart/mapping.html#1039196,其中不包括从Java char或Character到JDBC类型的映射.
您必须将值转换为String.
本文标题为:将Java Character对象值插入Oracle CHAR(1)列时出错
基础教程推荐
- JVM默认时区为:Asia/Shanghai与java程序中GMT+08不一致异常 2023-06-30
- MyBatis-Plus解决逻辑删除与唯一索引的问题 2023-04-07
- SpringBoot中的PUT和Delete请求使用 2023-02-11
- Java使用HttpClient实现文件下载 2023-04-12
- Spring Boot 整合持久层之MyBatis 2023-04-12
- Java redis使用场景介绍 2023-04-23
- IOC 容器启动和Bean实例化两个阶段详解 2023-04-12
- Java结构型设计模式之桥接模式详细讲解 2023-05-24
- Spring Bean注册与注入实现方法详解 2023-06-23
- Spring超详细讲解BeanUtils改造 2023-01-23