我在进行自我加入时遇到问题。
我有下表:
CREATE TABLE `test`.`tableN` (
`id` int(10) unsigned NOT NULL auto_increment,
`Group` int(10) unsigned NOT NULL,
`Item` int(10) unsigned NOT NULL,
`data` varchar(45) default NULL,
PRIMARY KEY (`id`)
)
ENGINE=InnoDB;
INSERT INTO `test`.`tableN` (`Group`,`Item`,`data`)
VALUES
(1,100,'aaa'),
(1,200,'bbb'),
(2,100,'ccc'),
(2,200,'ddd'),
(3,100,'eee');
然后我需要做的是运行一个查询,该查询在单个行中输出每个“项目”的数据。
我得到的查询是:
SELECT
t1.`Group`,
t1.`item`,
t1.`data`,
t2.`item`,
t2.`data`
FROM tableN t1
LEFT JOIN tableN t2 ON t2.`group`=t1.`group`
WHERE 1=1
AND t1.item = 100
AND t2.item = 200
GROUP BY t1.`Group`;
问题是,这只返回 2 行(第 1 组和第 2 组)。我还需要它为 Group=3 返回一行,即使 item=200 没有条目。
请问我该怎么做。