gpt4 book ai didi

mysql - Join:三张表和一个or条件

转载 作者:行者123 更新时间:2023-11-29 03:11:43 25 4
gpt4 key购买 nike

我想我应该以某种方式知道这一点,尤其是在阅读了很多关于“条件必须进入 ON 子句,而不是 WHERE 子句”的问题和答案之后。然而,我还是迷路了。

我有三个表,我通常使用 LEFT (OUTER) 连接来连接它们。连接的表看起来像这样(retty 标准):

task_id task_questions_taskId   taskQuestions_questionId    question_id1         1                     5                           51         1                     8                           82         2                     8                           8
SELECT `t`.`id` AS `task_id` , 
`task_questions`.`taskId` AS `task_questions_taskId` ,
`task_questions`.`questionId` AS `task_questions_questionId` ,
questions.id AS question_id
FROM `task` `t`
LEFT OUTER JOIN `task_questions` `task_questions`
ON ( `task_questions`.`taskId` = `t`.`id` )
LEFT OUTER JOIN `question` `questions`
ON ( `task_questions`.`questionId` = `questions`.`id` )

这是获取所有记录的标准查询。 (它取自 Yii;我实际上想用 Active Record 做到这一点,但甚至无法正确使用纯 SQL)。

现在我只想获取那些具有 question_id 2 和 8 的任务(例如)所以如果一个任务没有这两个 question.ids,我不希望它出现在结果集中。在这种情况下,任务也可以有其他 question_id。尽管如果查询只返回那些恰好具有那些 2(或任何其他集合)的查询,那么看看查询的外观会很有趣。很容易得到所有有一个问题的任务,WHERE question.id = 2,但是 WHERE 子句中的 AND 会导致空结果。

最佳答案

WHERE 子句一次只能对一行应用条件。但是你的不同 id 的问题出现在不同的行上。如何解决这个问题?使用自联接将两行合并为一行。

这是一个例子:

SELECT t.`id` AS `task_id`, ...
FROM `task` AS t
INNER JOIN `task_questions` AS tq2 ON ( tq2.`taskId` = t.`id` )
INNER JOIN `questions` AS q2 ON ( tq2.`questionId` = q2.`id` )
INNER JOIN `task_questions` AS tq8 ON ( tq8.`taskId` = t.`id` )
INNER JOIN `questions` AS q8 ON ( tq8.`questionId` = q8.`id` )
WHERE q2.`id` = 2 AND q8.`id` = 8

另一种解决方案是找到有问题 2 OR 8 的任务,然后使用 GROUP BY 和 HAVING 来过滤恰好有两个问题的组。

SELECT t.`id` AS `task_id`, ...
FROM `task` AS t
INNER JOIN `task_questions` AS tq ON ( tq.`taskId` = t.`id` )
INNER JOIN `questions` AS q ON ( tq.`questionId` = q.`id` )
WHERE tq.`questionId` IN (2, 8)
GROUP BY t.`id`
HAVING COUNT(DISTINCT q.`id`) = 2

关于mysql - Join:三张表和一个or条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7167248/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com