SQL我正确使用此连接吗?

时间:2014-04-18 20:42:23

标签: mysql sql

使用大学关系(不同部门的教师建议学生,每位学生只有一名顾问,但顾问可以有零到多的建议),我正在尝试编写一个函数来计算被建议的学生总数。某个部门。

以下是供参考的表格和列:

student(id,name,dept_name,tot_cred)
instructor(id,name,dept_name, salary)
advisor(s_id,i_id)

我已经知道如何使用分隔符,所以不需要告诉我如何编写函数。我只是单独从select语句中获得了我想要的东西。

这是迄今为止我能够提出的最好的:

SELECT * 
FROM advisor 
RIGHT OUTER JOIN instructor 
ON i_id=id 
ORDER BY dept_name;

本声明产生:

This statement yields a joined table containing both student and instructor ids organized by dept_name

有没有办法可以编写if语句或其他语句来删除所有NULL条目,然后使用count函数(在我将编写的自定义函数中),它将计算dept_name发生的实例数,导致每个部门的顾问总数?

4 个答案:

答案 0 :(得分:2)

SELECT i.dept_name, COUNT(a.s_id)
FROM Instructor i
    LEFT JOIN advisor a ON i.id = a.i_id
GROUP BY i.dept_name;

这将包括没有建议的部门的零。

答案 1 :(得分:1)

如果您对每个学生部门的建议学生人数感兴趣,那么:

SELECT s.dept_name, COUNT(a.s_id)
FROM      student s
LEFT JOIN advisor a ON a.s_id=s.id
GROUP BY s.dept_name

OTOH,如果您对每个讲师部门的建议学生人数感兴趣,那么:

SELECT i.dept_name, COUNT(a.s_id)
FROM      instructor i
LEFT JOIN advisor    a ON a.i_id=i.id
GROUP BY i.dept_name

答案 2 :(得分:0)

看起来这就是你所需要的:

SELECT i.dept_name, COUNT(a.s_id) FROM instructor i
LEFT OUTER JOIN advisor a ON i.id = a.i_id
GROUP BY i.dept_name;

我必须补充说,advisor(s_id,i_id)是一个糟糕的数据库设计,如果学生真的不能像你说的那样拥有超过1个顾问。因为在这种情况下,只需将advisor_id添加到学生关系中并删除顾问表。

另外:您使用'功能'是不正确的。我们在这里讨论查询。

答案 3 :(得分:0)

可能你可以试试这个:

SELECT i.dept_name, COUNT(s.*) AS totalAdvisedNum 
FROM student s, advisor a, instructor i
WHERE a.s_id = s.id AND a.i_id = i.id GROUP BY i.dept_name

这将选择部门名称和这些部门的教师建议的学生总数

如果您需要获取特定部门的编号,则应将 GROUP BY i.dept_name 替换为AND i.dept_name ="部门名称"