繁体   English   中英

转换我的内部连接sql语句EXISTS

[英]converting my inner join sql statement EXISTS

我认为以下语句会产生相同的结果……但事实并非如此。 包括'exists'语句在内的第一个代码似乎并没有限制'QuizID'列所选择的值,我认为应该...作为一个侧面说明,此列仅存在于'quizQuestions'中,而在'quizAnswers'中不存在

SELECT qa.QuestionNumber 
FROM QuizAnswers qa 
where exists (SELECT * 
              FROM QuizQuestions 
              WHERE QUIZID = 6)


SELECT qa.QuestionNumber 
FROM QuizAnswers qa 
   INNER JOIN QuizQuestions IQQ 
      ON qa.QuestionNumber = IQQ.QuestionNumber
WHERE QUIZID = 6

包含“内部联接”的语句包含我想要的结果集。为了获得相同的结果,我需要在Exists语句中包括哪些内容?

QuizQuestions表中的行的QUIZID6时,您的EXISTS查询正在执行的操作是选择所有问题编号。 如果有一行,它将选择所有问题编号,否则,将不选择任何一个。 您需要做的是使它与外部查询相关联 ,以便它依赖于每个QuestionNmber ...

您需要将AND QuestionNumber = qa.QuestionNumber作为EXISTS的第二个条件,以使其成为相关子查询。

这个查询

SELECT qa.QuestionNumber FROM QuizAnswers qa where exists ( SELECT * FROM QuizQuestions WHERE QUIZID = 6) 

相当于这个

SELECT qa.QuestionNumber FROM QuizAnswers qa 

如果QuizQuestions中有QuizID = 6的任何内容,请参见Zane的解决方案。根据您的SQL实现,通常最好使用INNER JOIN版本。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM