首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL我是否正确地使用了这个联接?

SQL我是否正确地使用了这个联接?
EN

Stack Overflow用户
提问于 2014-04-18 20:42:23
回答 4查看 848关注 0票数 1

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

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

代码语言:javascript
复制
student(id,name,dept_name,tot_cred)
instructor(id,name,dept_name, salary)
advisor(s_id,i_id)

我已经知道如何使用分隔符之类的了,所以不需要被告知如何编写函数。我只是很难从select语句中得到我想要的东西。

到目前为止,这是我能想到的最好的:

代码语言:javascript
复制
SELECT * 
FROM advisor 
RIGHT OUTER JOIN instructor 
ON i_id=id 
ORDER BY dept_name;

这一说法得出:

是否有一种方法可以编写if语句或其他语句来删除所有空条目,然后使用计数函数(在我将要编写的自定义函数中)来计数发生的实例dept_name的数量,从而导致每个部门的顾问总数?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2014-04-18 20:55:58

代码语言:javascript
复制
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;

这将包括没有顾问的部门的零。

票数 2
EN

Stack Overflow用户

发布于 2014-04-18 20:54:09

如果你对每个学生系建议的学生人数感兴趣,那么:

代码语言:javascript
复制
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,如果您对每个讲师部门建议的学生人数感兴趣,那么:

代码语言:javascript
复制
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
票数 1
EN

Stack Overflow用户

发布于 2014-04-18 20:45:30

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

代码语言:javascript
复制
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)数据库设计是很糟糕的。因为在这种情况下,只需将advisor_id添加到学生关系中,并去掉顾问表。

另外:你对“功能”这个词的使用是不正确的。我们在这里讨论的是查询。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23162000

复制
相关文章

相似问题

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