MySQL根据不同条件联查不同表的数据
项目开发中遇到类似的需求。Mybatis 中的< if >标签只能判断where部分,不能满足要求。在网上查解决方法,好像并没有可以完美解决问题的方案,if和case可以从某一种角度实现效果。
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)两产品的设备数。product表中字段product_type_id表示产品类型。如果是1就查device表,否则就查monitor表。
case
多于两种情况时
case的用法
CASE expr1 WHEN a THEN A WHEN … THEN … ELSE … END
判断expr1,满足不同条件时执行不同的语句。
注:最后以END结尾
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)
最后
这样能勉强实现效果,但并不是想象的那种。话说,这种情况是不是应该先查出共同的部分,再在service层进行判断,执行不同的语句。。