簡體   English   中英

在jooq中設置NULL值

[英]Set NULL value in 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>解析方法。

我應該如何進行?

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM