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

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

NVL與Coalesce之間的Oracle差異

NVL與Coalesce之間的Oracle差異

開滿天機(jī) 2019-08-01 14:31:33
NVL與Coalesce之間的Oracle差異Oracle中的NVL和Coalesce之間是否存在明顯差異?明顯的區(qū)別在于coalesce將返回其參數(shù)列表中的第一個(gè)非null項(xiàng),而nvl僅接受兩個(gè)參數(shù),如果不為null則返回第一個(gè),否則返回第二個(gè)。似乎NVL可能只是一個(gè)'基礎(chǔ)案例'版本的合并。我錯(cuò)過了什么嗎?
查看完整描述

3 回答

?
慕碼人8056858

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

COALESCE是更現(xiàn)代的功能,是ANSI-92標(biāo)準(zhǔn)的一部分。

NVLOracle具體的,它在推出80的前存在任何標(biāo)準(zhǔn)。

在兩個(gè)值的情況下,它們是同義詞。

但是,它們的實(shí)現(xiàn)方式不同。

NVL總是計(jì)算兩個(gè)參數(shù),同時(shí)COALESCE通常在找到第一個(gè)非結(jié)束時(shí)停止評(píng)估NULL(有一些例外,例如序列NEXTVAL):

SELECT  SUM(val)FROM    (
        SELECT  NVL(1, LENGTH(RAWTOHEX(SYS_GUID()))) AS val        FROM    dual        CONNECT BY
                level <= 10000
        )

它運(yùn)行了幾0.5秒鐘,因?yàn)樗闪?code>SYS_GUID(),盡管1不是NULL。

SELECT  SUM(val)FROM    (
        SELECT  COALESCE(1, LENGTH(RAWTOHEX(SYS_GUID()))) AS val        FROM    dual        CONNECT BY
                level <= 10000
        )

這理解1不是NULL并且不評(píng)估第二個(gè)參數(shù)。

SYS_GUID沒有生成,查詢是即時(shí)的。


查看完整回答
反對(duì) 回復(fù) 2019-08-01
?
白衣染霜花

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

NVL將隱式轉(zhuǎn)換為第一個(gè)參數(shù)的數(shù)據(jù)類型,因此以下內(nèi)容不會(huì)出錯(cuò)

select nvl('a',sysdate) from dual;

COALESCE期望一致的數(shù)據(jù)類型。

select coalesce('a',sysdate) from dual;

會(huì)拋出'不一致的數(shù)據(jù)類型錯(cuò)誤'


查看完整回答
反對(duì) 回復(fù) 2019-08-01
  • 3 回答
  • 0 關(guān)注
  • 1263 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號(hào)

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