av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

SQL Server ISNULL 不生效原因及解決

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

    SQL Server ISNULL 不生效原因

    數據庫:SQL Server 2008 R2

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

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

    問題

    用ISNULL只后數據依舊為NULL并沒有替換掉。

    原因

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

    解決方法

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

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

    不滿足條件時,則在 ELSE 下方寫 SQL。如此,數據進行了替換。 

    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 真是個坑,CPU飆升90% +

    • table1大概1100多萬數據
    • table2大概80多萬數據

    MES系統,使用了以下SQL語句,并且這個語句每分鐘終端會并發執行一次(大概30個客戶端)

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

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

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

    修改為 :aa.fanCode IS NOT NULL  后CPU回到個位數。

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

    以上為個人經驗,希望能給大家一個參考,也希望大家多多支持。 

    標簽: MsSQL
    主站蜘蛛池模板: 日本激情网站 | 在线观看小视频 | 四虎在线免费视频 | 日韩高清精品免费观看 | 欧美日韩综合在线 | 免费中文字幕日韩欧美 | av福利在线| 国产精品欧美一区二区 | 97人人视频 | 欧美精品成人 | 久久中文网| 中文字幕av久久爽av | 欧美日韩国产精品 | 欧美激情亚洲 | av激情影院| 日韩欧美高清 | 午夜网址 | 国产三级视频在线 | 国产成人精品一区二区三区视频 | 天堂成人网 | 在线视频日韩 | 一区二区三区黄色 | 国产欧美精品一区二区色综合 | 欧美激情第二页 | 国产精品美女久久久久久久久 | 日韩一区二区三区在线 | 日韩在线观看中文字幕 | 久久精品欧美一区 | 中文字幕一区二区三区四区视频 | 一区二区久久久 | 国产视频一区二区在线观看 | 毛片毛片毛片毛片毛片 | 国产欧美精品 | 高清一区二区 | 在线h片| 久久久久久久久久久国产 | 一区在线观看视频 | 国产亚洲天堂 | 欧美日韩国产精品 | 日本a在线观看 | 欧美综合色 |