1 回答

TA貢獻(xiàn)1818條經(jīng)驗(yàn) 獲得超7個(gè)贊
您的NULL表達(dá)式必須與您的列的類(lèi)型相同TEST.ID。我想這不是一String列,而是一些數(shù)字列。無(wú)論實(shí)際數(shù)據(jù)類(lèi)型如何,您始終可以使用另一個(gè)表達(dá)式的數(shù)據(jù)類(lèi)型創(chuàng)建綁定值,例如
// Bind variable:
DSL.val(null, TEST.ID)
// Inline value / NULL literal
DSL.inline(null, TEST.ID)
如果你經(jīng)常這樣做,你也可以像這樣提取你自己的實(shí)用程序:
public static <T> util(Field<?> nullable, Field<T> other) {
return when(nullable.isNull(), other).otherwise(inline(null, other));
}
NVL2注意,jOOQ 有一個(gè)用于此目的的內(nèi)置方法:
nvl2(TEST.PANEL_ID, inline(null, TEST.ID), TEST.ID).as("testId")
添加回答
舉報(bào)