我有一個很大的查詢,我的問題是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)但它沒有用,因為它無法解析方法 with jooq.Param<String>。我該如何進行?
1 回答

qq_笑_17
TA貢獻1818條經驗 獲得超7個贊
您的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));
}
NVL2注意,jOOQ 有一個用于此目的的內置方法:
nvl2(TEST.PANEL_ID, inline(null, TEST.ID), TEST.ID).as("testId")
添加回答
舉報
0/150
提交
取消