在jooq中设置NULL值

时间:2019-07-02 08:02:04

标签: java mysql sql jooq

我有一个很大的查询,我的问题是使用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>解析方法。

我应该如何进行?

1 个答案:

答案 0 :(得分:1)

您的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")