<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 431,  comments - 344,  trackbacks - 0
    四,根據(jù)條件有選擇的UPDATE。

    例,有如下更新條件
    1. 工資5000以上的職員,工資減少10%
    2. 工資在2000到4600之間的職員,工資增加15%
    很容易考慮的是選擇執(zhí)行兩次UPDATE語句,如下所示
    --條件1
    UPDATE Personnel
    SET salary = salary * 0.9
    WHERE salary >= 5000;
    --條件2
    UPDATE Personnel
    SET salary = salary * 1.15
    WHERE salary >= 2000 AND salary < 4600;
    

    但是事情沒有想象得那么簡單,假設(shè)有個人工資5000塊。首先,按照條件1,工資減少10%,變成工資4500。接下來運行第二個SQL時候,因為這個人的工資是4500在2000到4600的范圍之內(nèi), 需增加15%,最后這個人的工資結(jié)果是5175,不但沒有減少,反而增加了。如果要是反過來執(zhí)行,那么工資4600的人相反會變成減少工資。暫且不管這個規(guī)章是多么荒誕,如果想要一個SQL 語句實現(xiàn)這個功能的話,我們需要用到Case函數(shù)。代碼如下:
    UPDATE Personnel
    SET salary = CASE WHEN salary >= 5000
                 THEN salary * 0.9
    WHEN salary >= 2000 AND salary < 4600
    THEN salary * 1.15
    ELSE salary END;
    

    這里要注意一點,最后一行的ELSE salary是必需的,要是沒有這行,不符合這兩個條件的人的工資將會被寫成NUll,那可就大事不妙了。在Case函數(shù)中Else部分的默認值是NULL,這點是需要注意的地方。
    這種方法還可以在很多地方使用,比如說變更主鍵這種累活。
    一般情況下,要想把兩條數(shù)據(jù)的Primary key,a和b交換,需要經(jīng)過臨時存儲,拷貝,讀回數(shù)據(jù)的三個過程,要是使用Case函數(shù)的話,一切都變得簡單多了。
    p_key col_1 col_2
    a 1 張三
    b 2 李四
    c 3 王五


    假設(shè)有如上數(shù)據(jù),需要把主鍵ab相互交換。用Case函數(shù)來實現(xiàn)的話,代碼如下
    UPDATE SomeTable
    SET p_key = CASE WHEN p_key = 'a'
    THEN 'b'
    WHEN p_key = 'b'
    THEN 'a'
    ELSE p_key END
    WHERE p_key IN ('a', 'b');
    

    同樣的也可以交換兩個Unique key。需要注意的是,如果有需要交換主鍵的情況發(fā)生,多半是當初對這個表的設(shè)計進行得不夠到位,建議檢查表的設(shè)計是否妥當。

    五,兩個表數(shù)據(jù)是否一致的檢查。

    Case函數(shù)不同于DECODE函數(shù)。在Case函數(shù)中,可以使用BETWEEN,LIKE,IS NULL,IN,EXISTS等等。比如說使用IN,EXISTS,可以進行子查詢,從而 實現(xiàn)更多的功能。
    下面具個例子來說明,有兩個表,tbl_A,tbl_B,兩個表中都有keyCol列。現(xiàn)在我們對兩個表進行比較,tbl_A中的keyCol列的數(shù)據(jù)如果在tbl_B的keyCol列的數(shù)據(jù)中可以找到, 返回結(jié)果'Matched',如果沒有找到,返回結(jié)果'Unmatched'。
    要實現(xiàn)下面這個功能,可以使用下面兩條語句
    --使用IN的時候
    SELECT keyCol,
    CASE WHEN keyCol IN ( SELECT keyCol FROM tbl_B )
    THEN 'Matched'
    ELSE 'Unmatched' END Label
    FROM tbl_A;
    --使用EXISTS的時候
    SELECT keyCol,
    CASE WHEN EXISTS ( SELECT * FROM tbl_B
    WHERE tbl_A.keyCol = tbl_B.keyCol )
    THEN 'Matched'
    ELSE 'Unmatched' END Label
    FROM tbl_A;
    

    使用IN和EXISTS的結(jié)果是相同的。也可以使用NOT IN和NOT EXISTS,但是這個時候要注意NULL的情況。

    六,在Case函數(shù)中使用合計函數(shù)

    假設(shè)有下面一個表
    學號(std_id) 課程ID(class_id) 課程名(class_name) 主修flag(main_class_flg)
    100 1 經(jīng)濟學 Y
    100 2 歷史學 N
    200 2 歷史學 N
    200 3 考古學 Y
    200 4 計算機 N
    300 4 計算機 N
    400 5 化學 N
    500 6 數(shù)學 N

    有的學生選擇了同時修幾門課程(100,200)也有的學生只選擇了一門課程(300,400,500)。選修多門課程的學生,要選擇一門課程作為主修,主修flag里面寫入 Y。只選擇一門課程的學生,主修flag為N(實際上要是寫入Y的話,就沒有下面的麻煩事了,為了舉例子,還請多多包含)。
    現(xiàn)在我們要按照下面兩個條件對這個表進行查詢
    1. 只選修一門課程的人,返回那門課程的ID
    2. 選修多門課程的人,返回所選的主課程ID

    簡單的想法就是,執(zhí)行兩條不同的SQL語句進行查詢。
    條件1
    --條件1:只選擇了一門課程的學生
    SELECT std_id, MAX(class_id) AS main_class
    FROM Studentclass
    GROUP BY std_id
    HAVING COUNT(*) = 1;
    

    執(zhí)行結(jié)果1
    STD_ID   MAIN_class
    ------   ----------
    300      4
    400      5
    500      6
    

    條件2
    --條件2:選擇多門課程的學生
    SELECT std_id, class_id AS main_class
    FROM Studentclass
    WHERE main_class_flg = 'Y' ;
    

    執(zhí)行結(jié)果2
    STD_ID  MAIN_class
    ------  ----------
    100     1
    200     3
    

    如果使用Case函數(shù),我們只要一條SQL語句就可以解決問題,具體如下所示
    SELECT  std_id,
    CASE WHEN COUNT(*) = 1  --只選擇一門課程的學生的情況
    THEN MAX(class_id)
    ELSE MAX(CASE WHEN main_class_flg = 'Y'
    THEN class_id
    ELSE NULL END
    )
    END AS main_class
    FROM Studentclass
    GROUP BY std_id;
    

    運行結(jié)果
    STD_ID   MAIN_class
    ------   ----------
    100      1
    200      3
    300      4
    400      5
    500      6
    

    通過在Case函數(shù)中嵌套Case函數(shù),在合計函數(shù)中使用Case函數(shù)等方法,我們可以輕松的解決這個問題。使用Case函數(shù)給我們帶來了更大的自由度。
    最后提醒一下使用Case函數(shù)的新手注意不要犯下面的錯誤
    CASE col_1
    WHEN 1        THEN 'Right'
    WHEN NULL  THEN 'Wrong'
    END
    

    在這個語句中When Null這一行總是返回unknown,所以永遠不會出現(xiàn)Wrong的情況。因為這句可以替換成WHEN col_1 = NULL,這是一個錯誤的用法,這個時候我們應(yīng)該選擇用WHEN col_1 IS NULL。
    posted on 2008-09-24 11:29 周銳 閱讀(418) 評論(0)  編輯  收藏 所屬分類: MySQLOracleSQL Server
    主站蜘蛛池模板: 亚洲无线一二三四区手机| 亚洲av色福利天堂| 国产在线播放线91免费| 久久亚洲国产精品成人AV秋霞| 日韩在线播放全免费| 亚洲欧美日韩中文二区| 久久久久噜噜噜亚洲熟女综合| 久久永久免费人妻精品| 亚洲综合久久精品无码色欲| 亚洲成A人片在线观看中文| 日本免费在线观看| 亚洲乱码无人区卡1卡2卡3| 亚洲色偷偷综合亚洲AVYP| 嫖丰满老熟妇AAAA片免费看| 深夜福利在线视频免费| 亚洲福利一区二区精品秒拍| 免费真实播放国产乱子伦| 精品四虎免费观看国产高清午夜| 亚洲精品天堂在线观看| 久久精品国产亚洲一区二区| 无码人妻一区二区三区免费 | 久久综合日韩亚洲精品色| 国产片AV片永久免费观看 | 华人在线精品免费观看| 亚洲久热无码av中文字幕| 亚洲国产精品无码久久一区二区| 岛国av无码免费无禁网站| 99久久免费国产精精品| 亚洲sm另类一区二区三区| 亚洲日本中文字幕| 亚洲精品无码久久毛片| 巨胸喷奶水视频www网免费| 国产激情免费视频在线观看| 免费看一级一级人妻片| 亚洲看片无码在线视频| 久久丫精品国产亚洲av不卡| 久久影视国产亚洲| 四虎影库久免费视频| 成年女人午夜毛片免费看| 99re6在线精品视频免费播放| jizz18免费视频|