gpt4 book ai didi

java - jooq 的包含命名参数的子句

转载 作者:行者123 更新时间:2023-11-30 06:43:46 28 4
gpt4 key购买 nike

我使用 jooq 作为 SQL 生成引擎,然后使用 jdbi 执行这些查询。要将查询映射到其参数,我需要在 jdbi 中显式绑定(bind)它,但是当我将命名参数添加到 contains 子句时,参数名称会丢失。

这个测试用例显示了我对 getParams() 调用的期望

@Test
public void testJooqContains() {
DSLContext context = new DefaultDSLContext(SQLDialect.MYSQL);
Param<String> param = param("P1", "test");
Condition condition = field("Field1").contains(param);
SelectQuery<Record> select = context.selectQuery();
select.addSelect(field("Col1"));
select.addConditions(Collections.singletonList(condition));
select.addFrom(table("Table1").as("T1"));

assertTrue(select.getParams().containsKey("p1"));
}

最佳答案

这是 jOOQ 中的一个错误( #6223 ,已在 3.10、3.9.3、3.8.8 中修复),由 Java 语言规范 ( see also this question ) 中的微妙之处引起。

您的field("Field1").contains(param)编译器将调用链接到 Field.contains(T) 而不是预期的 Field.contains(Field<T>) 。发生这种情况是因为您的 field("Field1")表达式的类型为Field<Object> ,这意味着两种方法都适用。

解决此问题的方法是编写:

Condition condition = field("Field1", String.class).contains(param);

关于java - jooq 的包含命名参数的子句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43986668/

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