Java 如何在jdbi中绑定元组列表?

Java 如何在jdbi中绑定元组列表?,java,mysql,sql,jdbi,Java,Mysql,Sql,Jdbi,我有一个这种格式的mysql查询 SELECT * from xyz where (key1, key2) in (('val1', 'val2'), ('val3', 'val4')); 我正在使用jdbi进行此查询。如何绑定jdbi中的元组列表? 我想用这样的东西 List<String[]> query = new ArrayList<>(); for(String key: vars.keySet()){ String[] entry = {key, var

我有一个这种格式的mysql查询

SELECT * from xyz where (key1, key2) in (('val1', 'val2'), ('val3', 'val4'));
我正在使用jdbi进行此查询。如何绑定jdbi中的元组列表? 我想用这样的东西

List<String[]> query = new ArrayList<>();
for(String key: vars.keySet()){
  String[] entry = {key, vars.get(key)};
  query.add(entry);
}
List<String> result = getBasicQuery() + " WHERE (key, val) in (<query>)".bindList("query", query);

在JDBI3中实现这一点实际上相当容易,但由于某些原因,该解决方案没有在上进行记录

这是:

List<String> result = handle.createQuery(getBasicQuery() + " WHERE (key, val) in (<query>)")
    .bindMethodsList("query", query, List.of("getKey", "getValue"))
    .mapTo(String.class)
    .list();
或者,您可以通过将属性本身公开并使用来跳过getter

List<String> result = handle.createQuery(getBasicQuery() + " WHERE (key, val) in (<query>)")
    .bindMethodsList("query", query, List.of("getKey", "getValue"))
    .mapTo(String.class)
    .list();
class Query {
  String key;
  String value;

  Query(String key, String value) {
    this.key = key;
    this.value = value;
  }

  public String getKey() {
    return key;
  }

  public String getValue() {
    return value;
  }
}