Mysql 使用IF语句根据左连接获取所有字段

Mysql 使用IF语句根据左连接获取所有字段,mysql,sql,select,join,left-join,Mysql,Sql,Select,Join,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都引用了表1…基本上,我希望这样,如果左连接条目存在,它将返回左连接c2中的行,而如果它不存在,它将返回c1中的条目 但是,执行此查询将产生mysql语法错误。我如何完成我试图完成的任务(最好是在单个IF语句中)?

所以我有这个疑问

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都引用了表1…基本上,我希望这样,如果左连接条目存在,它将返回左连接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 answer一样,您可以在所需的每一列上使用
IF()
COALESCE()
函数来实现这一点

我能想到的唯一方法是使用
联合
并将两种情况分开:

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 ;