web-dev-qa-db-ja.com

jdbctemplateクエリにさまざまなタイプの引数を渡す

いくつかの異なるタイプの引数を使用して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"
}
9
Suleman khan

使ってください

public List<Dog> listByBreedIdAndGender(long breedId, String gender) {  
   return jdbcTemplate.query("SELECT * FROM dog_entity WHERE breed__id = :breedId AND gender =:gender", 
      new MapSqlParameterSource()
      .addValue("breedId", breedId)
      .addValue("gender", gender));
}

JdbcTemplateが NamedParameterJdbcTemplate であることを確認してください。

JdbcTemplate を使用する必要がある場合

    public List<Dog> listByBreedIdAndGender(long breedId, String gender) {  
       return jdbcTemplate.query
          ("SELECT * FROM dog_entity WHERE breed__id = ? AND gender = ?",
          new Object[] { breedId, gender }, 
          new DogRowMapper());         
    }

またはプライベートクエリメソッドの使用を主張する場合

public List<Dog> listByBreedIdAndGender(long breedId, String gender) {  
       return query
          ("SELECT * FROM dog_entity WHERE breed__id = ? AND gender = ?",
          new Object[] { breedId, gender });         
}

private List<Dog> query(String sql, Object[] parameters) {  
   List<Dog> dogs = jdbcTemplate.query(sql, parameters, new DogRowMapper());
   return dogs;

}

Breed__idの_文字数が正しいことを確認してください。

コンセプトは、NamedParameterJdbcTemplateを:nameで指定されたパラメーター(:genderなど)で使用するか、単純なJdbcTemplateを位置パラメーター(new Object [] {breedId、gender}のように使用することです。 。

17
Michal