MySQL如何根據(jù)不同條件聯(lián)查不同表的數(shù)據(jù)if/case
MySQL根據(jù)不同條件聯(lián)查不同表的數(shù)據(jù)
項目開發(fā)中遇到類似的需求。Mybatis 中的< if >標簽只能判斷where部分,不能滿足要求。
在網(wǎng)上查解決方法,好像并沒有可以完美解決問題的方案,if和case可以從某一種角度實現(xiàn)效果。
if
MySQL中if的用法:
IF(expr1,expr2,expr3)
類似三元運算符,判斷expr1,如果 expr1 是TRUE,則該語句的返回值為expr2; 否則返回值為 expr3。
SELECT product_id, IF(product_type_id=1, (SELECT COUNT(*) FROM `device` WHERE product_id = product.product_id), (SELECT COUNT(*) FROM `monitor`WHERE product_id = product.product_id)) as device_num FROM `product` WHERE product_id in (1,25)
查product_id為(1,25)兩產(chǎn)品的設(shè)備數(shù)。
product表中字段product_type_id表示產(chǎn)品類型。
如果是1就查device表,否則就查monitor表。

case
多于兩種情況時
case的用法
CASE expr1 WHEN a THEN A WHEN … THEN … ELSE … END
判斷expr1,滿足不同條件時執(zhí)行不同的語句。
注:最后以END結(jié)尾
SELECT product_id, CASE product_type_id WHEN 1 THEN (SELECT COUNT(*) FROM `device` WHERE product_id = product.product_id) WHEN 2 THEN (SELECT COUNT(*) FROM `monitor`WHERE product_id = product.product_id) ELSE (SELECT COUNT(*) FROM `other_device`WHERE product_id = product.product_id) END as device_num FROM `product` WHERE product_id in (1,11,25)

注意
這樣能勉強實現(xiàn)效果,但并不是想象的那種。
話說,這種情況是不是應(yīng)該先查出共同的部分,再在service層進行判斷,執(zhí)行不同的語句。。
MySQL兩表聯(lián)查,根據(jù)不同條件獲得不同數(shù)據(jù)
場景:
查找某張表中某一列的所有符合某種條件的條目的累加和,且該表和另一張表相關(guān)聯(lián)
查詢語句
select DISTINCT ?? ifnull((select sum(‘列名') from a, b where a.id = b.id and a.condition=condition1 and b.condition = condition2),0) as '條件1下的數(shù)據(jù)' , ifnull((select sum(‘列名') from a, b where a.id = b.id and a.condition=condition3 and b.condition = condition4),0) as '條件2下的數(shù)據(jù)' from a, b where a.id = b.id?
缺點:數(shù)據(jù)量一太大就會be崩潰
優(yōu)化后語句
select ‘別名1', ‘別名2' from? (select IFNULL(sum(‘列名'),0) ‘別名1' from a, b where a.id = b.id and a.condition=condition1 and b.condition = condition2),0) t1 left join? (select IFNULL(sum(‘列名'),0) ‘別名2' from a, b where a.id = b.id and a.condition=condition3 and b.condition = condition4) t2 on 1=1
left join查詢比select嵌套查詢效率高的原因:執(zhí)行子查詢時,MYSQL需要創(chuàng)建臨時表,查詢完畢后再刪除這些臨時表,所以,子查詢的速度會受到一定的影響,這里多了一個創(chuàng)建和銷毀臨時表的過程。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL聯(lián)合查詢之輕松實現(xiàn)數(shù)據(jù)關(guān)聯(lián)詳解
MySQL中當查詢數(shù)據(jù)來自多張表時需要用到關(guān)聯(lián)查詢,下面這篇文章主要給大家介紹了關(guān)于MySQL聯(lián)合查詢之輕松實現(xiàn)數(shù)據(jù)關(guān)聯(lián)的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-06-06
ubuntu系統(tǒng)中安裝mysql5.6(通過二進制)
今天工作中需要對一臺ubantu的系統(tǒng)安裝mysql,因為以前一直使用的是centos,雖然它也是類unix但是和redhat或centos命令上還是有點差別。所以通過網(wǎng)上查閱資料,終于安裝成功了,現(xiàn)在將步驟分享給大家,有需要的朋友們可以參考借鑒。2016-10-10
MySQL億級數(shù)據(jù)平滑遷移雙寫方案實戰(zhàn)
預(yù)約業(yè)務(wù)與其他業(yè)務(wù)數(shù)據(jù)表存儲在同一個數(shù)據(jù)庫,當其他業(yè)務(wù)出現(xiàn)慢SQL等異常時,會影響到預(yù)約業(yè)務(wù),為了提高系統(tǒng)穩(wěn)定性和數(shù)據(jù)隔離性,需要將預(yù)約數(shù)據(jù)表從原來的數(shù)據(jù)庫中遷移出來,單獨建立數(shù)據(jù)庫,涉及到的讀寫場景多,改造成本大,采用 Mybatis插件實現(xiàn)遷移所需的雙寫等功能2024-08-08
mysql使用mysqld_multi部署單機多實例的方法教程
這篇文章主要給大家介紹了關(guān)于mysql使用mysqld_multi部署單機多實例的相關(guān)資料,文中通過示例代碼將實現(xiàn)的步驟一步步介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2018-03-03
mysql連接數(shù)設(shè)置操作方法(Too many connections)
下面小編就為大家?guī)硪黄猰ysql連接數(shù)設(shè)置操作方法(Too many connections)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03
MySQL表數(shù)據(jù)文件損壞導致數(shù)據(jù)庫無法啟動的原因與解決方案
在日常的數(shù)據(jù)庫管理中,遇到MySQL表數(shù)據(jù)文件損壞的情況并不罕見,這種情況下,MySQL數(shù)據(jù)庫可能會無法正常啟動,給業(yè)務(wù)運行帶來嚴重影響,本文將探討如何診斷和解決MySQL表數(shù)據(jù)文件損壞導致的數(shù)據(jù)庫無法啟動問題,需要的朋友可以參考下2025-03-03

