第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

在 jooq 中設(shè)置 NULL 值

在 jooq 中設(shè)置 NULL 值

一只斗牛犬 2023-03-02 09:43:41
我有一個(gè)很大的查詢,我的問題是NULL使用 jooq 設(shè)置值。例如,我有這樣一段 sql 查詢:IF(t.PANEL_ID IS NULL, t.ID, NULL) AS testId如果將其轉(zhuǎn)換為 jooq 實(shí)現(xiàn),則會(huì)出現(xiàn)如下內(nèi)容:when(TEST.PANEL_ID.isNull(), TEST.ID).otherwise(null)).as("testId")但這是模棱兩可的方法調(diào)用。我做了一些研究,找到了這個(gè)片段:DSL.val((String) null)但它沒有用,因?yàn)樗鼰o法解析方法 with jooq.Param<String>。我該如何進(jìn)行?
查看完整描述

1 回答

?
qq_笑_17

TA貢獻(xiàn)1818條經(jīng)驗(yàn) 獲得超7個(gè)贊

您的NULL表達(dá)式必須與您的列的類型相同TEST.ID。我想這不是一String列,而是一些數(shù)字列。無論實(shí)際數(shù)據(jù)類型如何,您始終可以使用另一個(gè)表達(dá)式的數(shù)據(jù)類型創(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")


查看完整回答
反對 回復(fù) 2023-03-02
  • 1 回答
  • 0 關(guān)注
  • 240 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號