gpt4 book ai didi

java - 如何在 jdbi 中绑定(bind)元组列表?

转载 作者:行者123 更新时间:2023-11-30 12:06:14 25 4
gpt4 key购买 nike

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

SELECT * from xyz where (key1, key2) in (('val1', 'val2'), ('val3', 'val4'));

我正在使用 jdbi 进行此查询。如何绑定(bind) 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);

以这种方式使用绑定(bind)时出现此错误

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

最佳答案

在 JDBI3 中实际上很容易做到这一点,但由于某种原因,解决方案没有记录在 jdbi.org 上.

这里是:

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

注意使用bindMethodsList()您需要将查询对象定义为具有公共(public)方法(即 getter)的类的实例。像这样的东西会工作得很好:

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;
}
}

或者,您可以通过公开属性本身并使用 bindBeanList() 来跳过 getter。 .

关于java - 如何在 jdbi 中绑定(bind)元组列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55702129/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com