- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
说明是“打印所有注册学生少于六人的类(class)的类(class)名称、类(class)编号和部分编号。”
我提出了两个查询,想知道是否有人可以告诉我我做错了什么,或者您是否可以指导我获得结果。我尝试运行这两个查询,但没有得到任何结果。我完全不知道将 <6 语句放在第二个查询中的何处。
这是我的表格:
Student(sid,sname,sex,age,year,qpa)
Dept(dname,numphds)
Prof (pname,dname)
Course (cno,cname,dname)
Major(dname,sid)
Section(dname,cno,sectno,pname)
Enroll(sid,grade,dname,cno,sectno)
CREATE TABLE course (
cno INT,
cname VARCHAR(100),
dname VARCHAR(100)
);
INSERT INTO course VALUES ( 302, 'Intro to Programming', 'Computer Sciences' );
INSERT INTO course VALUES ( 310, 'Thermodynamics', 'Chemical Engineering' );
查询1:
SELECT course.cname, course.cno, enroll.sectno, COUNT (*)
FROM course
JOIN enroll on enroll.cno = course.cno AND enroll.sid = student.sid
WHERE COUNT(*)<6;
GROUP BY cname, cno, sectno;
查询2:
SELECT course.cname, course.cno, enroll.cno, enroll.sectno, COUNT (*)
FROM course, enroll, student
WHERE course.cno = enroll.cno AND enroll.sid = student.sid
GROUP BY cname, cno, sectno;
我正在测试此查询来运行我的程序:
SELECT course.cname, course.cno, enroll.sectno, COUNT (*)
FROM course
JOIN enroll on enroll.cno = course.cno AND enroll.sid = student.sid
GROUP BY cname, cno, sectno
HAVING COUNT(*)<6;
最佳答案
您应该将计数移至 HAVING
条款。 WHERE
用于过滤传入数据(来自表)。剩余的数据将被处理,并根据您的情况进行汇总(计数)。之后,您可以使用HAVING
过滤这些聚合结果。子句:
SELECT course.cname, course.cno, enroll.sectno, COUNT (*)
FROM course
JOIN enroll on enroll.cno = course.cno AND enroll.sid = student.sid
GROUP BY cname, cno, sectno
HAVING COUNT(*)>6
另请注意,查询中间有一个分号。这基本上将查询分为两个查询,其中一个查询是愚蠢的,另一个查询显然是无效的。请使用合适的工具,它不会只是返回“无”,而是会显示语法错误的实际错误消息,否则调试将非常麻烦。
{编辑}
经过讨论和您修改后的问题,我认为问题是您还没有任何学生(或者至少根本没有链接到类(class)。此外, > 6
应该是 < 6
。查询将是:
SELECT c.cname, c.cno, e.sectno, COUNT(e.sid) as studentcount
FROM course c
LEFT JOIN enroll e on e.cno = c.cno
GROUP BY c.cname, c.cno, e.sectno
HAVING COUNT(e.sid) < 6
这里修复了一些问题:
JOIN
更改为LEFT JOIN
,所以如果没有 enroll
仍然返回类(class)根本就没有相关记录。COUNT(*)
更改为COUNT(enroll.sid)
,因此如果没有学生注册该类(class),它将返回 0(否则它将返回 1,因为它计算“任何”字段,包括类(class)本身的字段)。> 6
更改为< 6
因为您想要开设少数学生的类(class)。enroll.sid
的加入至student.sid
去掉了。此连接不完整。条件已经存在,但您根本没有在查询中包含学生表,这使得查询无效。您不需要学生表,因为您只需计算学生 ID,这些 ID 也在 enroll
中。 ,所以我完全省略了该连接。GROUP BY
中的字段名称引用了表(别名)。子句,否则你可能会收到“不明确的列名”错误,尽管我不确定 MySQL 如何处理这种情况。无论如何,在任何地方使用表名或别名都会使其更具可读性。剩下的问题是是否需要按e.sectno
分组,但这需要你自己去弄清楚。 :)
关于MySQL HELP - 需要从所有类(class)的三个表中打印,其中注册的学生少于六名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26319477/
我有一个字符串,我想多次使用它来输出 configure --help .所以我尝试在 configure.ac 中做这样的事情: AC_ARG_ENABLE([foobar],
我无法使其正确匹配。它只打印“[help]”,但我希望它匹配括号内的字符。 想要: [help] help 代码: Pattern p = Pattern.compile("\\[(\
我刚刚将vim74下载并安装到我的linux机器上。我只是为用户安装在本地。当我进入vim并执行:help时,我得到了错误。 我尝试添加: let $VIM='home/myuser/vim74' l
当我打开一个 Xcode 项目时,快速帮助功能工作得很好,但是当打开一个不在打开的项目中的文件(例如 abc.swift )时,文档不会出现。 下面是一个例子: 最佳答案 安装版本Command Li
我有一个 python click CLI。当我将 --help 传递给任何命令时,它会打印一条我喜欢的帮助消息。我发现现在很多用户都在输入 mycli help foo 而不是 mycli foo
我一直在使用 less 进行前端开发,但最近几天我遇到了这个错误。 我正在使用 PhpStorm 的观察器将 less 文件编译为 css 文件。但是当我编辑 less 文件时,编译器将这一行添加到
当我在 python 解释器中键入 help('string') 时,我得到了有关字符串类的信息。在那里,upper() 被表示为一个函数。然而,我只能将其称为 "hi".upper() 而不是 up
我希望 help 选项的作用与 --help 相同。 旁注:我创建了一个程序,其命令行行为与 svn 或 hg 相同。我设法用子解析器做到了这一点。但是我想让事情保持一致。这就是为什么我希望 help
我是 Maven 的新手。你知道我做错了什么吗(见下文)? mvn -e clean:help. + Error stacktraces are turned on. [INFO] Scannin
help format-list输出格式列表的帮助。 format-list | help输出帮助(get-help)。 最佳答案 该|或“管道”运算符将一个操作的输出重定向到另一个。因此,在这种情况
尝试从脚本检索帮助会出现以下错误: Get-Help : Cannot find Help for topic ".\Process-Test.ps1". At line:1 char:9 + get
我从常规的discord.py更改为重写版本,并且我曾经有一个自定义的!help命令。 现在,每当我发布 !help 时,它都会显示此内容以及编码的帮助消息: No Category: help S
我开发跨平台桌面应用程序,最近我发现了在小部件上使用帮助文本的乐趣。然后用户在标题栏上有一个问号按钮,单击该按钮后,他可以单击窗口中的任何小部件并查看有关它的帮助文本。非常好。 因为我认为所有程序都应
Xcode 4.5.2 Mountain Lion,Mac 应用 我严格遵守文档。帮助文件夹及其子文件夹已添加到项目/Resources 文件夹并显示为蓝色。 如有必要,文件夹引用由 xcode 添加
emulator documentation说: -audio-in Use the specified audio-input backend. 它还说 -help- Print
最近在学习argparse模块,代码下方出现Argument错误 import argparse import sys class ExecuteShell(object): def crea
我正在阅读有关 Maven 的教程,应该提到我对此一无所知。我已经成功地完成了第一章和第二章,这是关于它的设置的。但是在第 3 章“Maven Pom”中我遇到了问题。在最后一段中,它说在你想要的任何
我注意到 Windows 有这个问题,但我运行的是 Ubuntu 13.10(带有 Bash),所以我不知道出了什么问题。 尝试设置我的副本集,我运行以下命令: sudo bash # Accout
很抱歉,我在 python 程序中遇到了一个尴尬的问题。首先我是这里的新手,我是一名中国学生。请原谅我糟糕的英语。我会尽力把问题表达清楚。 错误代码在这里: def __find__(
好的,我试图环顾四周并弄清楚如何做到这一点,但无法弄清楚。这就是我想要做的。 # Run script normally .\myscript.ps1 "blah" "yo" 这些应该做同样的事情 G
我是一名优秀的程序员,十分优秀!