开发者

MySQL full inner join

开发者 https://www.devze.com 2023-03-05 06:52 出处:网络
I have SELECT clientReport.id FROM clientReport LEFT JOIN report02 ON (report02.id = clientReport.id)

I have

SELECT clientReport.id 
FROM clientReport 
LEFT JOIN report02 ON (report02.id = clientReport.id)
WHERE report02.id is null;

that does the equivalent of

SELECT clientReport.id
WHERE clientReport.rowNumber NOT EXISTS (
SELECT clientReport.rowNumber FROM report02, clientReport
WHERE report02.id=clientReport.id);

I need, presumably, a full inner join to also get mismatches in report02, not just clientReport. How do I write the joi开发者_运维知识库n to do this?


The below should work.

SELECT clientReport.id,report02.id
FROM clientReport 
FULL OUTER JOIN report02 ON (report02.id = clientReport.id)
WHERE report02.id is null
OR clientReport.id is null;

It should but it doesn't (as MySQL does not currently support FULL OUTER JOIN.)

This is more likely to work:

( SELECT clientReport.id  AS report01
       , report02.id      AS report02
  FROM clientReport 
  LEFT  OUTER JOIN report02
      ON (report02.id = clientReport.id)
  WHERE report02.id IS NULL
)
UNION
( SELECT clientReport.id  AS report01
       , report02.id      AS report02
  FROM clientReport 
  RIGHT OUTER JOIN report02
      ON (report02.id = clientReport.id)
  WHERE clientReport.id is null
)
0

精彩评论

暂无评论...
验证码 换一张
取 消