首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MYSQL连接混淆

MYSQL连接混淆
EN

Stack Overflow用户
提问于 2011-10-14 21:41:31
回答 3查看 64关注 0票数 1

我有这个考试表和答题表。我要获取Exam for exam = 000663的所有记录

代码语言:javascript
复制
SELECT COUNT(*)
  FROM Responses r  
  JOIN Exams E ON r.category_id_fk = E.id 
              AND r.exam_id_fk = 000663

实际上总共有106行,只包含考试000663的答案。但是它返回所有考试的所有响应行!它不应该考虑r.exam_id_fk = 000663吗?

我没有使用where子句,因为我有另外3个表连接到这个查询。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-10-14 21:44:31

000663条件属于WHERE子句,而不属于JOIN关系条件。即使您有其他表对此进行联接(作为子查询),您仍然可以使用WHERE子句。

代码语言:javascript
复制
select count(*)
from  Responses r  
join Exams E on r.category_id_fk = E.id 
WHERE r.exam_id_fk=000663;
票数 4
EN

Stack Overflow用户

发布于 2011-10-14 21:47:55

假设E.id是考试id,r.exam_id_fk也是考试id尝试

代码语言:javascript
复制
select count(*)
from Exams e
left join Responses r on r.exam_id_fk = e.id
where e.id = 000663;

看起来您正在加入等于类别id的考试id,并且您的条件应该在where子句中

票数 0
EN

Stack Overflow用户

发布于 2011-10-14 21:52:11

我猜您使用的列名不正确。使用AND e.id = 000663而不是AND r.exam_id_fk = 000663,这样查询就可以在没有WHERE的情况下工作。

代码语言:javascript
复制
SELECT COUNT(*)
FROM Responses r  
JOIN Exams E ON r.category_id_fk = E.id 
AND e.id = 000663
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7768512

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档