请看下面的测试案例:
CREATE TABLE accounts (id int);
CREATE TABLE emails (id int, account_id int, type_name varchar(10), order_id int);
INSERT INTO accounts VALUES (1), (2), (3), (4);
INSERT INTO emails VALUES (1, 1, 'name', 1);
INSERT INTO emails VALUES (2, 1, 'no-name', 1);
INSERT INTO emails VALUES (3, 2, 'name', 1);
INSERT INTO emails VALUES (4, 2, 'no-name', 1);
INSERT INTO emails VALUES (5, 3, 'name', 2);
那么这个按预期工作:
SELECT * FROM `accounts`
LEFT OUTER JOIN `emails` ON emails.account_id = accounts.id
WHERE (emails.type_name = 'name' AND emails.order_id = 1);
+------+------+------------+-----------+----------+
| id | id | account_id | type_name | order_id |
+------+------+------------+-----------+----------+
| 1 | 1 | 1 | name | 1 |
| 2 | 3 | 2 | name | 1 |
+------+------+------------+-----------+----------+
2 rows in set (0.00 sec)
与你的第二个查询的问题是,它可以返回一个NULL
行,如果有与帐户没有电子邮件,为的就是账号4的情况下:
SELECT * FROM `accounts`
LEFT OUTER JOIN `emails` ON emails.account_id = accounts.id
WHERE (!(emails.type_name = 'name' AND emails.order_id = 1) OR emails.id IS NULL);
+------+------+------------+-----------+----------+
| id | id | account_id | type_name | order_id |
+------+------+------------+-----------+----------+
| 1 | 2 | 1 | no-name | 1 |
| 2 | 4 | 2 | no-name | 1 |
| 3 | 5 | 3 | name | 2 |
| 4 | NULL | NULL | NULL | NULL |
+------+------+------------+-----------+----------+
4 rows in set (0.01 sec)
为什么不这是足够的,没有NULL
行?:
SELECT * FROM `accounts`
LEFT OUTER JOIN `emails` ON emails.account_id = accounts.id
WHERE NOT (emails.type_name = 'name' AND emails.order_id = 1)
+------+------+------------+-----------+----------+
| id | id | account_id | type_name | order_id |
+------+------+------------+-----------+----------+
| 1 | 2 | 1 | no-name | 1 |
| 2 | 4 | 2 | no-name | 1 |
| 3 | 5 | 3 | name | 2 |
+------+------+------------+-----------+----------+
3 rows in set (0.00 sec)
感谢详细的回复!对于第二个查询,我正在查找没有特定类型电子邮件记录的帐户(type_name ='name'AND order_id = 1)。在你的例子中,帐户1和2有这种电子邮件记录,所以我不希望那些返回。帐户3的电子邮件记录不匹配,所以我希望返回。帐户4没有电子邮件记录,所以我希望返回,因为它不匹配。 总结:我的查询目前返回帐户1,2,3和4.我只希望它返回3和4. – tassock 2010-07-23 18:06:52