jdbc调用中出现“未知数据类型”错误

时间:2016-09-23 15:48:31

标签: java sql postgresql date jdbc

我正在尝试使用Callable Statement在Java中调用Postgres函数。函数的输入参数之一是Timestamp类型。当我尝试从java调用该函数时,我收到以下错误。

ERROR: function insrt_data(character varying, integer, bigint, unknown, character varying) does not exist

我的功能签名是:

insrt_data(
i_cd character varying,
i_prog_id smallint,
i_stat_id bigint,
i_dt date,
i_stat_cd character varying) RETURNS character varying

我的jdbc调用如下。 StrtDt是一个java.util.Date字段。

String sql = "{call mySchema.insrt_data(?, ?, ?, ?, ?)}";    
java.sql.Date StartDt = new java.sql.Date(record.getStrtDt().getTime());
Map<String, Object> map = jdbcTemplate.call(connection -> {
            CallableStatement statement = connection.prepareCall(sql);
            statement.setString(1, record.getCd());
            statement.setInt(2, record.getProgId());
            statement.setLong(3, record.getId());
            statement.setDate(4, StartDt);
            statement.setString(5, record.getStatCd());
            statement.registerOutParameter(1, Types.VARCHAR);
            return statement;
        }, paramList);

1 个答案:

答案 0 :(得分:0)

问题在于i_prog_cd。在我传递smallint时,函数需要int作为值。 Postgres的smallint对应于java中的short。将其更改为short后,代码就可以了!