久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

SQL Server ISNULL 不生效原因及解決

瀏覽:144日期:2023-03-06 14:25:35
目錄
  • SQL Server ISNULL 不生效原因
    • 問題
    • 原因
    • 解決方法
  • SQL Server ISNULL 真是個(gè)坑,CPU飆升90% +

    SQL Server ISNULL 不生效原因

    數(shù)據(jù)庫:SQL Server 2008 R2

    原始SQL:historyval 字段沒有數(shù)據(jù)顯示為NULL,用ISNULL判斷為NULL的時(shí)候替換為 0.0

    SELECT
    ?? ?ISNULL(historyval, 0.0)
    FROM
    ?? ?ce_bf_l_energyh_t_2
    WHERE
    ?? ?tagname = "123"

    問題

    用ISNULL只后數(shù)據(jù)依舊為NULL并沒有替換掉。

    原因

    ISNULL只作用于查詢出數(shù)據(jù)后字段為NULL可以替換生效、如果查詢的時(shí)候這條數(shù)據(jù)本身為NULL、字段替換時(shí)ISNULL則不生效。

    解決方法

    先用 if exists(結(jié)果集)判斷這條數(shù)據(jù)是否存在(也就是說這條select這條sql有沒有結(jié)果集),BEGIN 表示語句塊的開始;END 表示語句塊的結(jié)束(加不加 BEGIN  END 代碼塊都可以)。

    如果滿足條件直接在下方寫 SQL。

    不滿足條件時(shí),則在 ELSE 下方寫 SQL。如此,數(shù)據(jù)進(jìn)行了替換。 

    IF EXISTS (
    ?? ?SELECT
    ?? ??? ?ISNULL(historyval, 0.0)
    ?? ?FROM
    ?? ??? ?ce_bf_l_energyh_t_2
    ?? ?WHERE
    ?? ??? ?tagname = "123"
    )
    BEGIN
    ?? ?--如果存在
    ?? ?SELECT
    ?? ??? ?ISNULL(historyval, 0.0)
    ?? ?FROM
    ?? ??? ?ce_bf_l_energyh_t_2
    ?? ?WHERE
    ?? ??? ?tagname = "123"
    ?? ?END
    ?? ?ELSE
    ?
    ?? ?BEGIN
    ?? ??? ?--如果不存在
    ?? ??? ?SELECT
    ?? ??? ??? ?0.0
    ?? ??? ?END

    SQL Server ISNULL 真是個(gè)坑,CPU飆升90% +

    • table1大概1100多萬數(shù)據(jù)
    • table2大概80多萬數(shù)據(jù)

    MES系統(tǒng),使用了以下SQL語句,并且這個(gè)語句每分鐘終端會(huì)并發(fā)執(zhí)行一次(大概30個(gè)客戶端)

    SELECT
    ? ? AA.id?
    FROM
    ? ?table1 aa
    ? ? LEFT JOIN table2 ?bb ON bb.No= aa.No?
    WHERE

    --就下面這句,把服務(wù)器CPU干到90%多

    isnull( aa.fanCode,"0")!="0"?

    修改為 :aa.fanCode IS NOT NULL  后CPU回到個(gè)位數(shù)。

    總結(jié):盡量少用isnull()函數(shù),就算用也盡量不用在where后面。 

    以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持。 

    標(biāo)簽: MsSQL
    主站蜘蛛池模板: 胶州市| 绍兴县| 衡阳县| 荆州市| 东乡县| 邵武市| 苏尼特右旗| 西丰县| 临沭县| 河西区| 丹棱县| 金平| 株洲县| 西吉县| 桐庐县| 普陀区| 资中县| 大庆市| 连平县| 富源县| 永川市| 射洪县| 三明市| 拜泉县| 安塞县| 芜湖县| 奎屯市| 灵璧县| 遵化市| 二连浩特市| 右玉县| 绍兴市| 盐边县| 鄂州市| 中卫市| 明光市| 阿荣旗| 肥西县| 吉隆县| 庆云县| 二手房|