萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> MySQL中使用自定義變量 編寫偷懶的UNION示例

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

以下是對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表中查詢得到的。

copyright © 萬盛學電腦網 all rights reserved