Установите значение NULL в jooq

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

Как мне поступить?

Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
2
0
4 872
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 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")

Другие вопросы по теме