【发布时间】:2020-12-26 02:23:15
【问题描述】:
我正在尝试使用带有几个不同类型参数的 where 子句从数据库中检索记录。这是我编写的简单方法,其中我将breedId 和gender 作为参数传递。
public List<Dog> listByBreedIdAndGender(long breedId, String gender) {
return query("SELECT * FROM dog_entity WHERE breed__id = ? AND gender = ?",
new MapSqlParameterSource(":breedId", breedId)
.addValue(":gender", gender));
}
private List<Dog> query(String sql, MapSqlParameterSource parameters) {
List<Dog> dogs = jdbcTemplate.query(sql, new DogRowMapper(), parameters);
return dogs;
}
我运行了这个方法,但得到了以下异常。谁能告诉我如何将多个参数传递给 jdbcTemplate.query(),我对它有点陌生。
{
timestamp: 1419637479460
status: 500
error: "Internal Server Error"
exception: "org.springframework.dao.TransientDataAccessResourceException"
message: "PreparedStatementCallback; SQL [SELECT * FROM dog_entity WHERE breed__id = ? AND gender = ?]; Invalid argument value: java.io.NotSerializableException; nested exception is java.sql.SQLException: Invalid argument value: java.io.NotSerializableException"
path: "/api/2/m"
}
【问题讨论】:
标签: spring spring-mvc jdbctemplate