MySQL中使用自訂變數 編寫偷懶的UNION樣本

來源:互聯網
上載者:User
以下是對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表中查詢得到的。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.