繁体   English   中英

使用IF语句获取所有字段,具体取决于LEFT JOIN

[英]using IF statement to get all fields depending on the LEFT JOIN

所以我有这个查询

SELECT IF(c2.nid IS NULL, c.*, c2.*) FROM table1 c LEFT JOIN table1 c2 ON c.cid = c2.pid WHERE c.pid = 0 AND c.nid = 674662;

请注意,c和c2都引用了table1 ....基本上,我想要它,以便如果存在左联接条目,它将返回左联接c2中的行,而如果不存在,它将返回c1中的条目...

但是,执行此查询将产生mysql语法错误..我该如何完成我想完成的工作(最好在单个IF语句中)?

我担心您不能在IF语句中使用星形模式。 因此,您需要像这样明确输入

SELECT IF(c2.nid IS NULL, c.cid, c2.cid), 
       IF(c2.nid IS NULL, c.pid, c2.pid), ... 
FROM table1 c LEFT JOIN table1 c2 ON c.cid = c2.pid 
WHERE c.pid = 0 AND c.nid = 674662;

作为@luksch的答案,您可以通过在所需的每一列上使用IF()COALESCE()函数来实现。

我能想到的唯一方法是使用UNION并拆分两种情况:

SELECT c2.*
FROM table1 c 
  INNER JOIN table1 c2 ON c.cid = c2.pid 
WHERE c.pid = 0 AND c.nid = 674662

UNION ALL

SELECT c.*
FROM table1 c 
  LEFT JOIN table1 c2 ON c.cid = c2.pid 
WHERE c.pid = 0 AND c.nid = 674662
  AND c2.pid IS NULL ;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM