将不同类型的参数传递给 jdbctemplate 查询

Posted

技术标签:

【中文标题】将不同类型的参数传递给 jdbctemplate 查询【英文标题】:passing different types of arguments to jdbctemplate query 【发布时间】: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"

【问题讨论】:

【参考方案1】:

请使用

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 其中breedId匹配第一个?和性别第二个?)。

【讨论】:

仍然出现同样的错误。我还需要对我的私有方法进行任何更改吗? 我正在使用这个导入import org.springframework.jdbc.core.JdbcTemplate; 所以使用我推荐的那个。 感谢您的快速回复!我实际上有更多的方法,它们将有更多不同类型的参数,这就是我的私有方法,这样我就不会一遍又一遍地重复同样的事情。无论如何我只需要在我想要的任何参数的私人调用中修改它。 对不起,这是题外话,但对我来说,你的私人方法几乎没用。如果您调用私有方法,您将保存实例变量 jdbcTemplate 和 fest-wired 的新 DogRowMapper。这对你没有多大帮助,无论是在打字方面还是在抽象方面。

以上是关于将不同类型的参数传递给 jdbctemplate 查询的主要内容,如果未能解决你的问题,请参考以下文章

Java:将具有不同类型的参数传递给函数

将参数传递给角度指令

无法将多个参数传递给 SQL 语句到通配符 [重复]

将 C# 数据类型参数传递给用 C++ 编写的 dll?

将表值参数传递给具有不同字段数的存储过程

使用django模板将参数传递给页面上的Javascript代码?