问题背景
我试图使用spring框架将一条记录插入到数据库中。作为这个过程的一部分,我在DAO类中创建了一个SQL字符串(参见下面),它接受一些参数并将它们插入到我声明为字段的查询字符串中。如果前端用户(挂起/禁用)选择了某些条件,则数据库中有两个字段设置为当前日期。
问题是Spring不允许我将字符串SYSDATE作为参数注入到我的查询中,它希望它是一个数字类型,因为我的数据库中的列是DATE类型。
与其创建4个单独的SQL字符串来容纳用户做出的四种可能的选择(未禁用/挂起、挂起、禁用、禁用和挂起),我更希望只有一个语句将值SYSDATE插入到SQL字符串中,这取决于传递给调用方法的值。
SQL字符串
(上面的方法实际上接受了在JdbcTemplate的update方法中显示的那些数据类型的变量,但只是为了让您对我传递的参数有一个粗略的了解)
private final static String createNewObject = "INSERT INTO my_table"
+ "(ID, \"MODEL\", STATUS, OVERRIDE, DISABLED) "
+ "VALUES "
+ "(?, ?, ?, ?, ?)";Caused By: java.sql.SQLDataException: ORA-01858: a non-numeric character was found where a numeric was expected
期望输出
我想知道是否有一种方法可以使这种单一查询方法工作,而不是为用户选择的每一种可能的条件提供单独的查询。
发布于 2016-01-25 10:07:59
尝试new Object[] {1, "t-1000", "good", new Date(), new Date() };而不是new Object[] {1, "t-1000", "good", "SYSDATE", "SYSDATE"});
https://stackoverflow.com/questions/34989489
复制相似问题