gpt4 book ai didi

sql - MYSQL查询INNER JOIN两张表

转载 作者:行者123 更新时间:2023-11-29 01:02:11 24 4
gpt4 key购买 nike

我有三个表 CLASSESCHILD_CLASSESSTUDENTS

CLASSES 看起来像这样(它的自引用):

CLASS_ID | CLASS_PARENT |
-------------------------
1 | ---
2 | 1
3 | 2

CHILD_CLASSES 看起来像这样:

CC_ID | PARENT_CLASS_ID | CHILD_CLASS_ID
----------------------------------------
1 | 1 | 2
2 | 1 | 3
3 | 2 | 3

STUDENTS 看起来像这样

 STU_ID | CLASS_ID | STU_NAME
----------------------------
1 | 1 | A
2 | 1 | B
3 | 2 | C

CLASSES 表基本上是自引用的,但每个 CLASS 也可以有与该类关联的子级。所以 CLASS 1 有 child 2 和 3,而 Class 2 只有 3 岁的 child 。

所以很多学生可以有相同的类(class)ID。学生还可以查看所有与他们关联的 class_id 的子信息,因此类(class) ID 为 1 的任何学生都可以看到类(class) 1、2 和 3,但类(class)想法为 2 的学生只能看到类(class)ID 为 2 和 3。我试图找到一个查询来计算具有访问权限的特定类的用户数。因此,如果我正在查看 class_id 为 1 的查询将返回 3,因为它在 CHILD_CLASSES 表中有两个子项,然后在类表中有它自己。我似乎无法让它工作,但我总是做空,因为由于试图计算 CLASSES 表中的 1 个用户。

目前我使用的查询是这个

SELECT COUNT(class_id) as TOTAL 
FROM students
WHERE class_id IN (SELECT class_id
FROM child_classes
WHERE parent_class_id = 1);

最佳答案

看起来 child_classes 包含与 classes 相同的数据,因此以下应该有效:

SELECT COUNT(*)
FROM students
WHERE class_id = 1
OR class_id IN ( SELECT child_class_id
FROM child_classes
WHERE parent_class_id = 1
)

它返回具有 class_id = 1 或属于具有 parent_class_id = 1 的类(class)的所有 students 的计数。

关于sql - MYSQL查询INNER JOIN两张表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2381857/

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