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

时间:2019-04-16 06:47:29

标签: 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, vars.get(key)};
  query.add(entry);
}
List<String> result = getBasicQuery() + " WHERE (key, val) in (<query>)".bindList("query", query);

以这种方式使用绑定时遇到此错误

 No argument factory registered for '[Ljava.lang.String;@11fa461a' of type class [Ljava.lang.String;

1 个答案:

答案 0 :(得分:0)

在JDBI3中执行此操作实际上非常容易,但是由于某种原因,该解决方案未记录在jdbi.org上。

这里是:

whereIn

请注意,要使用bindMethodsList(),您需要将查询对象定义为具有公共方法(即getter)的类的实例。这样的事情就可以了:

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

或者,您可以通过将属性本身设为公开并使用bindBeanList()来跳过获取方法。