jooq 的包含命名参数的子句
jooq's contain clause with named params
我使用 jooq 作为 SQL 生成引擎,然后使用 jdbi 执行这些查询。
要将查询映射到它们的参数,我需要在 jdbi 中显式绑定它,但是当我将命名参数添加到 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, fixed for 3.10, 3.9.3, 3.8.8) caused by a subtlety in the Java language specification (see also this question) 中的错误。
编译器将您的 field("Field1").contains(param)
调用链接到 Field.contains(T)
instead of the expected Field.contains(Field<T>)
。发生这种情况是因为您的 field("Field1")
表达式属于 Field<Object>
类型,这意味着这两种方法都适用。
解决此问题的方法是编写:
Condition condition = field("Field1", String.class).contains(param);
我使用 jooq 作为 SQL 生成引擎,然后使用 jdbi 执行这些查询。 要将查询映射到它们的参数,我需要在 jdbi 中显式绑定它,但是当我将命名参数添加到 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, fixed for 3.10, 3.9.3, 3.8.8) caused by a subtlety in the Java language specification (see also this question) 中的错误。
编译器将您的 field("Field1").contains(param)
调用链接到 Field.contains(T)
instead of the expected Field.contains(Field<T>)
。发生这种情况是因为您的 field("Field1")
表达式属于 Field<Object>
类型,这意味着这两种方法都适用。
解决此问题的方法是编写:
Condition condition = field("Field1", String.class).contains(param);