| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4112 人关注过本帖
标题:[讨论]查询选修课程成绩均在80分以上的学生学号
只看楼主 加入收藏
jiushiwo
Rank: 1
等 级:新手上路
帖 子:170
专家分:0
注 册:2007-3-10
收藏
 问题点数:0 回复次数:5 
[讨论]查询选修课程成绩均在80分以上的学生学号
--23.查询选修课程成绩均在80分以上的学生学号
SELECT S.sno
FROM S
WHERE S.sno NOT in
(SELECT S.sno
FROM SC,S
WHERE S.sno=SC.sno AND SC.grade<80 );
这样查询有一个错误就是,如果在我的成绩表里有学生95004,没有选修课程,他就没有成绩,如果我用这种查询、结果会出现95001和95004,明明95004都没有成绩的为什么他会出现在查询结果里呢,如果我把95004加进去,且grade=75则查询只出现95001这样结果就正确了。为什么呢?
搜索更多相关主题的帖子: 学号 课程 学生 选修 查询 
2007-04-20 12:04
cyyu_ryh
Rank: 8Rank: 8
等 级:贵宾
威 望:45
帖 子:1899
专家分:176
注 册:2006-10-21
收藏
得分:0 
WHERE S.sno=SC.sno AND SC.grade<80 );
你不是说大于80的吗?
怎么还用小于符号哦?

有事无事都密我. MSN: cyyu_ryh@hotmail.co.jp E-mail: cyyu_ryh@
2007-04-20 12:43
棉花糖ONE
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:32
帖 子:2987
专家分:0
注 册:2006-7-13
收藏
得分:0 
--23.查询选修课程成绩均在80分以上的学生学号
SELECT S.sno
FROM S
WHERE S.sno NOT in
(SELECT sno
FROM SC
WHERE grade<80 );
或者
select sno from s where not exists(select 1 from sc where sc.sno=s.sno and grade<80)

26403021 sql群 博客 blog./user15/81152/index.shtml
2007-04-20 13:00
jiushiwo
Rank: 1
等 级:新手上路
帖 子:170
专家分:0
注 册:2007-3-10
收藏
得分:0 
以下是引用棉花糖ONE在2007-4-20 13:00:26的发言:
--23.查询选修课程成绩均在80分以上的学生学号
SELECT S.sno
FROM S
WHERE S.sno NOT in
(SELECT sno
FROM SC
WHERE grade<80 );
或者
select sno from s where not exists(select 1 from sc where sc.sno=s.sno and grade<80)
糖兄:用这语句不会出错,而且结果为95001,但是如果我把95004的选修课程删除了,就是说95004没有选修课,我再用这语句查询时就会出现95001 95004两个结果了,这是为什么呢

做你自己! everything will go! lanfei_1234@
2007-04-20 13:58
jiushiwo
Rank: 1
等 级:新手上路
帖 子:170
专家分:0
注 册:2007-3-10
收藏
得分:0 
还有一个问题想问下:要创建视图是不是也是在查询分析器里创建的啊?

怎么我在查询分析器里创建是都说有错,

做你自己! everything will go! lanfei_1234@
2007-04-20 14:26
hzjwcx
Rank: 2
等 级:新手上路
威 望:3
帖 子:60
专家分:0
注 册:2006-12-18
收藏
得分:0 
以下是引用jiushiwo在2007-4-20 13:58:47的发言:
糖兄:用这语句不会出错,而且结果为95001,但是如果我把95004的选修课程删除了,就是说95004没有选修课,我再用这语句查询时就会出现95001 95004两个结果了,这是为什么呢

SELECT S.sno
FROM S
WHERE S.sno NOT in
(SELECT sno
FROM SC
WHERE grade<80 );
或者
select sno from s where not exists(select 1 from sc where sc.sno=s.sno and grade<80)
你把95004的選修課刪除後,95004選修課grade就不存在,就會出現這種結果了


2007-04-20 14:57
快速回复:[讨论]查询选修课程成绩均在80分以上的学生学号
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.023878 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved