程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> MySQL中使用自定義變量 編寫偷懶的UNION示例

MySQL中使用自定義變量 編寫偷懶的UNION示例

編輯:關於MYSQL數據庫
    以下是對MySQL中使用自定義變量,編寫一個UNION的示例進行了詳細的介紹,需要的朋友可以過來參考下  

    (參考自<<高性能MySQL>>)
    假設有這樣的需求:寫一個UNION查詢,其第一個子查詢作為分支先執行,如果找到了匹配的行,則不再執行第二個分支的查詢。

    一般來說,我們可以寫出這樣的UNION查詢:

    復制代碼 代碼如下:
    select id from users where id=123456
    union all
    select id from users_archived where id = 123456;


    此查詢可以正常運行,但是無論在users表中是否找到記錄,都會到users_archived表中掃描一次;因此可能也會返回重復的記錄。為了減少這種情況下不必要的開銷,SQL語句可以寫成這樣:

    復制代碼 代碼如下:
    SELECT GREATEST(@found := -1, id) AS id, 'users' AS which_tbl
    FROM users WHERE id  = 1
    UNION ALL
        SELECT id, 'users_archived'
        FROM users_archived WHERE id = 1 and @found IS NULL
    UNION ALL
        SELECT 1, 'reset' FROM DUAL WHERE (@found := NULL) IS NOT NLL;


    上 面的查詢用到了自定義變量@found,通過在結果列中做一次賦值並且放在GREATEST函數中,以避免返回額外的數據。如果第一個分支查詢結果集為 NULL,那@found自然也還是NULL,因此會執行第二個分支查詢。另外,為了不影響後面的遍歷結果,在查詢的末尾將@found重置為NULL。

    另外, 返回的第二列數據是為了說明這條記錄是在users表還是在users_archived表中查詢得到的。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved