JDBC ResultSet提供了getObject,getInt,getString等方法,而PreparedStatement具有类似的setter.除了类型编译时类型安全之外,类型特定的getter/setter是否具有任何(dis)优势,或者可以在任何地方使用getObject/setObject吗?
没有真正的技术(dis)优势.如果您之后正在进行类型检查/投射,它们可能仅在功能上不利.
我自己ResultSet#getObject()只在返回的值是DB默认的基元时才使用,NULL并且声明的值是基元的包装器.例如Integer age:
user.setAge(resultSet.getObject("age") != null ? resultSet.getInt("age") : null);
Run Code Online (Sandbox Code Playgroud)
我PreparedStatement#setObject()实际上一直使用实用方法:
public static void setValues(PreparedStatement preparedStatement, Object... values) throws SQLException {
for (int i = 0; i < values.length; i++) {
preparedStatement.setObject(i + 1, values[i]);
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3003 次 |
| 最近记录: |