我有一个大查询,我的问题是使用jooq设置NULL值。
例如,我有一个sql查询:

IF(t.PANEL_ID IS NULL, t.ID, NULL) AS testId

如果将其转换为jooq实现,就会出现这样的情况:
when(TEST.PANEL_ID.isNull(), TEST.ID).otherwise(null)).as("testId")

但这是不明确的方法调用。
我做了一些调查,发现了这个片段:
DSL.val((String) null)

但它不起作用,因为它不能用jooq.Param<String>解析方法。
我该怎么做?

最佳答案

NULL表达式的类型必须与TEST.ID列的类型相同。我想这不是一个String列,而是一个数字列。不管实际的数据类型如何,您始终可以使用另一个表达式的数据类型创建绑定值,例如。

// Bind variable:
DSL.val(null, TEST.ID)

// Inline value / NULL literal
DSL.inline(null, TEST.ID)

如果您经常这样做,您还可以提取自己的实用程序,如下所示:
public static <T> util(Field<?> nullable, Field<T> other) {
    return when(nullable.isNull(), other).otherwise(inline(null, other));
}

注意,jOOQ有一个用于此目的的内置方法NVL2
nvl2(TEST.PANEL_ID, inline(null, TEST.ID), TEST.ID).as("testId")

关于java - 在jooq中设置NULL值,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/56847906/

10-15 17:54