setObject() PreparedStatement 的方法

2022-09-02 01:58:26

是否可以对所有数据类型(如 、 或 )使用 的方法?setObject()PreparedStatementStringintdouble

如果我使用它,可能会有什么问题?

protected void fillStatement(PreparedStatement stmt, Object[] params)
        throws SQLException {

        if (params == null) {
            return;
        }

        for (int i = 0; i < params.length; i++) {
            if (params[i] != null) {
                stmt.setObject(i + 1, params[i]);
            } else {
                stmt.setNull(i + 1, Types.OTHER);
            }
        }
    }

答案 1

我只与MySQL一起使用,我从来没有遇到过问题。我不能代表其他数据库或其他供应商。setObject()


答案 2

Blob 或专用日期字段(如 MSSQL DateTimeOffeet)可能存在问题。

另外,我发现了一个问题“无法在java.lang.Character和JAVA_OBJECT之间转换”。

如果参数是单字符类型。

    if (param instanceof Character) {
        param = "" + param;
    }

推荐