У меня большой запрос, и моя проблема заключается в установке значений NULL с помощью jooq.
Например, у меня есть этот кусок 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")