JdbcTemplate中的queryforInt / queryforLong方法在Spring 3.2中已弃用。我无法找出使用这些方法替换现有代码的最佳做法的原因或原因。
一种典型的方法:
int rowCount = jscoreJdbcTemplate.queryForInt(
"SELECT count(*) FROM _player WHERE nameKey = ? AND teamClub = ?",
playerNameKey.toUpperCase(),
teamNameKey.toUpperCase()
);
好的,上面的方法需要重写如下:
Object[] params = new Object[] {
playerNameKey.toUpperCase(),
teamNameKey.toUpperCase()
};
int rowCount = jscoreJdbcTemplate.queryForObject(
"SELECT count(*) FROM _player WHERE nameKey = ? AND teamClub = ?",
params, Integer.class);
显然这种弃用使得JdbcTemplate类更简单(或者是吗?)。 QueryForInt总是一种方便的方法(我猜)并且已经存在了很长时间。为什么删除它。结果代码变得更加复杂。
答案 0 :(得分:106)
我认为有人意识到queryForInt / Long方法具有令人困惑的语义,即从JdbcTemplate源代码中可以看到它的当前实现:
@Deprecated
public int queryForInt(String sql, Object... args) throws DataAccessException {
Number number = queryForObject(sql, args, Integer.class);
return (number != null ? number.intValue() : 0);
}
这可能会让你认为如果结果集为空它将返回0,但它会引发异常:
org.springframework.dao.EmptyResultDataAccessException: Incorrect result size: expected 1, actual 0
所以以下实现基本上等同于当前的实现:
@Deprecated
public int queryForInt(String sql, Object... args) throws DataAccessException {
return queryForObject(sql, args, Integer.class);
}
然后现在必须用丑陋的代码替换未弃用的代码:
queryForObject(sql, new Object { arg1, arg2, ...}, Integer.class);
或者这个(更好):
queryForObject(sql, Integer.class, arg1, arg2, ...);
答案 1 :(得分:33)
我同意原来的海报,即弃用方便方法queryForLong(sql)是一种不便。
我使用Spring 3.1开发了一个应用程序,并且刚刚更新到最新的Spring版本(3.2.3)并注意到它已被弃用。
幸运的是,这对我来说是一线改变:
return jdbcTemplate.queryForLong(sql); // deprecated in Spring 3.2.x
已更改为
return jdbcTemplate.queryForObject(sql, Long.class);
一些单元测试似乎表明,上述变化有效。
答案 2 :(得分:14)
不赞成使用queryForObject(String, Class)
。
答案 3 :(得分:13)
替换此类代码:
long num = jdbcTemplate.queryForLong(sql);
使用此代码:
long num = jdbcTemplate.queryForObject(sql, Long.class);
非常危险,因为如果列具有null值,则queryForObject将返回null,并且我们知道原始类型不能为null,并且您将具有NullPointerException。编译器没有警告你这件事。您将在运行时了解此错误。如果您有返回基本类型的方法,则会出现相同的错误:
public long getValue(String sql) {
return = jdbcTemplate.queryForObject(sql, Long.class);
}
Spring 3.2.2中JdbcTemplate中不推荐使用的方法queryForLong具有以下主体:
@Deprecated
public long queryForLong(String sql) throws DataAccessException {
Number number = queryForObject(sql, Long.class);
return (number != null ? number.longValue() : 0);
}
你看到它们返回原始值之前,检查它是否为空,如果它为null则返回0.顺便说一下 - 应该是0L。
答案 4 :(得分:2)
JdbcTemplate#queryForInt
返回0.无法区分一个案例与另一个案例。我认为这是该方法被弃用的主要原因。 BTW,ResultSet#getInt
表现相似。但是,我们可以通过ResultSet#wasNull
来区分这两种情况。
答案 5 :(得分:-1)
public int getCircleCount() {
Object param = "1";
String sql = "select count(*) from circle where id = ? ";
jdbcTemplate.setDataSource(getDataSource());
int result = getJdbcTemplate().queryForObject(sql, new Object[] { param }, Integer.class);
return result;
}