Student(S#,Sname,Sage,Ssex)学生表
Course(C#,Cname,T#)课程表
SC(S#,C#,score)成绩表
Teacher(T#,Tname)教师表
查询“001”课程比“002”课程成绩高的所有学生的学号;
selecta.S#from(selects#,scorefromSCwhereC#='001') a,(selects#,score
fromSCwhereC#='002') b
wherea.score>b.scoreanda.s#=b.s#;
查询平均成绩大于60 分的同学的学号和平均成绩;
selectS#,avg(score)
fromsc
group byS#havingavg(score)>60;
查询所有同学的学号、姓名、选课数、总成绩;
selectStudent.S#,Student.Sname,count(SC.C#),sum(score)
fromStudentleft Outer joinSConStudent.S#=SC.S#
group byStudent.S#,Sname
查询姓“李”的老师的个数;
selectcount(distinct(Tname))
fromTeacher
whereTnamelike'李%';
查询没学过“叶平”老师课的同学的学号、姓名;
selectStudent.S#,Student.Sname
fromStudent
whereS#not in(select distinct( SC.S#)fromSC,Course,TeacherwhereSC.C#=Course.C#and
Teacher.T#=Course.T#andTeacher.Tname='叶平');
查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;
selectStudent.S#,Student.SnamefromStudent,SCwhereStudent.S#=SC.S#andSC.C#='001'and
exists(Select*fromSCasSC_2whereSC_2.S#=SC.S#andSC_2.C#='002');
查询学过“叶平”老师所教的所有课的同学的学号、姓名;
selectS#,Sname
fromStudent
whereS#in(selectS#fromSC ,Course ,TeacherwhereSC.C#=Course.C#andTeacher.T#=Course.T#
andTeacher.Tname='叶平'group byS#havingcount(SC.C#)=(selectcount(C#)fromCourse,Teacher
whereTeacher.T#=Course.T#andTname='叶平'));
查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名;
SelectS#,Snamefrom(selectStudent.S#,Student.Sname,score ,(selectscorefromSC SC_2where
SC_2.S#=Student.S#andSC_2.C#='002') score2
fromStudent,SCwhereStudent.S#=SC.S#andC#='001') S_2wherescore2
查询所有课程成绩小于60 分的同学的学号、姓名;
selectS#,Sname
fromStudent
whereS#not in(selectStudent.S#fromStudent,SCwhereS.S#=SC.S#andscore>60);
查询没有学全所有课的同学的学号、姓名;
selectStudent.S#,Student.Sname
fromStudent,SC
whereStudent.S#=SC.S#group byStudent.S#,Student.Snamehavingcount(C#)
count(C#)fromCourse);
查询至少有一门课与学号为“1001”的同学所学相同的同学的学号和姓名;
selectS#,SnamefromStudent,SCwhereStudent.S#=SC.S#andC#inselectC#fromSCwhere
S#='1001';
查询至少学过学号为“001”同学所有一门课的其他同学学号和姓名;
select distinctSC.S#,Sname
fromStudent,SC
whereStudent.S#=SC.S#andC#in(selectC#fromSCwhereS#='001');
把“SC”表中“叶平”老师教的课的成绩都更改为此课程的平均成绩;
updateSCsetscore=(selectavg(SC_2.score)
fromSC SC_2
whereSC_2.C#=SC.C# )fromCourse,TeacherwhereCourse.C#=SC.C#andCourse.T#=Teacher.T#
andTeacher.Tname='叶平');
查询和“1002”号的同学学习的课程完全相同的其他同学学号和姓名;
selectS#fromSCwhereC#in(selectC#fromSCwhereS#='1002')
group byS#havingcount(*)=(selectcount(*)fromSCwhereS#='1002');
删除学习“叶平”老师课的SC 表记录;
Delect SC
fromcourse ,Teacher
whereCourse.C#=SC.C#andCourse.T#=Teacher.T#andTname='叶平';
向SC 表中插入一些记录,这些记录要求符合以下条件:没有上过编号“003”课程的同学学号002
号课的平均成绩;
InsertSCselectS#,'002',(Selectavg(score)
fromSCwhereC#='002')fromStudentwhereS#not in(SelectS#fromSCwhereC#='003');
按平均成绩从高到低显示所有学生的“数据库”、“企业管理”、“英语”三门的课程成绩,按如下形式显
示: 学生ID,,数据库,企业管理,英语,有效课程数,有效平均分
SELECTS#as学生ID
,(SELECTscoreFROMSCWHERESC.S#=t.S#ANDC#='004')AS数据库
,(SELECTscoreFROMSCWHERESC.S#=t.S#ANDC#='001')AS企业管理
,(SELECTscoreFROMSCWHERESC.S#=t.S#ANDC#='006')AS英语
,COUNT(*)AS有效课程数,AVG(t.score)AS平均成绩
FROMSCASt
GROUP BYS#
ORDER BYavg(t.score)
查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分
SELECTL.C#As课程ID,L.scoreAS最高分,R.scoreAS最低分
FROMSC L ,SCASR
WHEREL.C#=R.C#and
L.score=(SELECTMAX(IL.score)
FROMSCASIL,StudentASIM
WHEREL.C#=IL.C#andIM.S#=IL.S#
GROUP BYIL.C#)
AND
R.Score=(SELECTMIN(IR.score)
FROMSCASIR
WHERER.C#=IR.C#
GROUP BYIR.C#
);
按各科平均成绩从低到高和及格率的百分数从高到低顺序
SELECTt.C#AS课程号,max(course.Cname)AS课程名,isnull(AVG(score),0)AS平均成绩
,100*SUM(CASEWHENisnull(score,0)>=60THEN1ELSE0END)/COUNT(*)AS及格百分数
FROMSC T,Course
wheret.C#=course.C#
GROUP BYt.C#
ORDER BY100*SUM(CASEWHENisnull(score,0)>=60THEN1ELSE0END)/COUNT(*)DESC
查询如下课程平均成绩和及格率的百分数(用"1 行"显示): 企业管理(001),马克思(002),OO&UML
(003),数据库(004)
SELECTSUM(CASEWHENC#='001'THENscoreELSE0END)/SUM(CASEC#WHEN'001'THEN1
ELSE0END)AS企业管理平均分
,100*SUM(CASEWHENC#='001'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='001'THEN1ELSE0END)AS企业管理及格百分数
,SUM(CASEWHENC#='002'THENscoreELSE0END)/SUM(CASEC#WHEN'002'THEN1
ELSE0END)AS马克思平均分
,100*SUM(CASEWHENC#='002'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='002'THEN1ELSE0END)AS马克思及格百分数
,SUM(CASEWHENC#='003'THENscoreELSE0END)/SUM(CASEC#WHEN'003'THEN1
ELSE0END)ASUML平均分
,100*SUM(CASEWHENC#='003'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='003'THEN1ELSE0END)ASUML及格百分数
,SUM(CASEWHENC#='004'THENscoreELSE0END)/SUM(CASEC#WHEN'004'THEN1
ELSE0END)AS数据库平均分
,100*SUM(CASEWHENC#='004'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='004'THEN1ELSE0END)AS数据库及格百分数
FROMSC
查询不同老师所教不同课程平均分从高到低显示
SELECTmax(Z.T#)AS教师ID,MAX(Z.Tname)AS教师姓名,C.C#AS课程ID,MAX(C.Cname)AS课程
名称,AVG(Score)AS平均成绩
FROMSCAST,CourseASC ,TeacherASZ
whereT.C#=C.C#andC.T#=Z.T#
GROUP BYC.C#
ORDER BYAVG(Score)DESC
查询如下课程成绩第3 名到第6 名的学生成绩单:企业管理(001),马克思(002),UML (003),
数据库(004)
[学生ID],[学生姓名],企业管理,马克思,UML,数据库,平均成绩
SELECT DISTINCT top3
SC.S#As学生学号,
Student.SnameAS学生姓名,
T1.scoreAS企业管理,
T2.scoreAS马克思,
T3.scoreASUML,
T4.scoreAS数据库,
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)as总分
FROMStudent,SCLEFT JOINSCAST1
ONSC.S#=T1.S#ANDT1.C#='001'
LEFT JOINSCAST2
ONSC.S#=T2.S#ANDT2.C#='002'
LEFT JOINSCAST3
ONSC.S#=T3.S#ANDT3.C#='003'
LEFT JOINSCAST4
ONSC.S#=T4.S#ANDT4.C#='004'
WHEREstudent.S#=SC.S#and
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)
NOT IN
(SELECT
DISTINCT
TOP15WITHTIES
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)
FROMsc
LEFT JOINscAST1
ONsc.S#=T1.S#ANDT1.C#='k1'
LEFT JOINscAST2
ONsc.S#=T2.S#ANDT2.C#='k2'
LEFT JOINscAST3
ONsc.S#=T3.S#ANDT3.C#='k3'
LEFT JOINscAST4
ONsc.S#=T4.S#ANDT4.C#='k4'
ORDER BYISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)
DESC);
统计列印各科成绩,各分数段人数:课程ID,课程名称,[100-85],[85-70],[70-60],[ <60]
SELECTSC.C#as课程ID, Cnameas课程名称
,SUM(CASEWHENscoreBETWEEN85AND100THEN1ELSE0END)AS[100 - 85]
,SUM(CASEWHENscoreBETWEEN70AND85THEN1ELSE0END)AS[85 - 70]
,SUM(CASEWHENscoreBETWEEN60AND70THEN1ELSE0END)AS[70 - 60]
,SUM(CASEWHENscore<60THEN1ELSE0END)AS[60 -]
FROMSC,Course
whereSC.C#=Course.C#
GROUP BYSC.C#,Cname;
查询学生平均成绩及其名次
SELECT1+(SELECTCOUNT(distinct平均成绩)
FROM(SELECTS#,AVG(score)AS平均成绩
FROMSC
GROUP BYS#
)AST1
WHERE平均成绩>T2.平均成绩)as名次,
S#as学生学号,平均成绩
FROM(SELECTS#,AVG(score)平均成绩
FROMSC
GROUP BYS#
)AST2
ORDER BY平均成绩desc;
查询各科成绩前三名的记录:(不考虑成绩并列情况)
SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数
FROMSC t1
WHEREscoreIN(SELECT TOP3score
FROMSC
WHEREt1.C#=C#
ORDER BYscoreDESC
)
ORDER BYt1.C#;
查询每门课程被选修的学生数
selectc#,count(S#)fromscgroup byC#;
查询出只选修了一门课程的全部学生的学号和姓名
selectSC.S#,Student.Sname,count(C#)AS选课数
fromSC ,Student
whereSC.S#=Student.S#group bySC.S# ,Student.Snamehavingcount(C#)=1;
查询男生、女生人数
Selectcount(Ssex)as男生人数fromStudentgroup bySsexhavingSsex='男';
Selectcount(Ssex)as女生人数fromStudentgroup bySsexhavingSsex='女';
查询姓“张”的学生名单
SELECTSnameFROMStudentWHERESnamelike'张%';
查询同名同性学生名单,并统计同名人数
selectSname,count(*)fromStudentgroup bySnamehavingcount(*)>1;;
1981年出生的学生名单(注:Student 表中Sage 列的类型是datetime)
selectSname,CONVERT(char(11),DATEPART(year,Sage))asage
fromstudent
whereCONVERT(char(11),DATEPART(year,Sage))='1981';
查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列
SelectC#,Avg(score)fromSCgroup byC#order byAvg(score),C#DESC;
查询平均成绩大于85 的所有学生的学号、姓名和平均成绩
selectSname,SC.S# ,avg(score)
fromStudent,SC
whereStudent.S#=SC.S#group bySC.S#,Snamehavingavg(score)>85;
查询课程名称为“数据库”,且分数低于60 的学生姓名和分数
SelectSname,isnull(score,0)
fromStudent,SC,Course
whereSC.S#=Student.S#andSC.C#=Course.C#andCourse.Cname='数据库'andscore<60;
查询所有学生的选课情况;
SELECTSC.S#,SC.C#,Sname,Cname
FROMSC,Student,Course
whereSC.S#=Student.S#andSC.C#=Course.C# ;
查询任何一门课程成绩在70 分以上的姓名、课程名称和分数;
SELECT distinctstudent.S#,student.Sname,SC.C#,SC.score
FROMstudent,Sc
WHERESC.score>=70ANDSC.S#=student.S#;
查询不及格的课程,并按课程号从大到小排列
selectc#fromscwherescor e<60order byC# ;
查询课程编号为003 且课程成绩在80 分以上的学生的学号和姓名;
selectSC.S#,Student.SnamefromSC,StudentwhereSC.S#=Student.S#andScore>80and
C#='003';
求选了课程的学生人数
selectcount(*)fromsc;
查询选修“叶平”老师所授课程的学生中,成绩最高的学生姓名及其成绩
selectStudent.Sname,score
fromStudent,SC,Course C,Teacher
whereStudent.S#=SC.S#andSC.C#=C.C#andC.T#=Teacher.T#andTeacher.Tname='叶平'and
SC.score=(selectmax(score)fromSCwhereC#=C.C# );
查询各个课程及相应的选修人数
selectcount(*)fromscgroup byC#;
查询不同课程成绩相同的学生的学号、课程号、学生成绩
select distinctA.S#,B.scorefromSC A ,SC BwhereA.Score=B.ScoreandA.C#<>B.C# ;
查询每门功成绩最好的前两名
SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数
FROMSC t1
WHEREscoreIN(SELECT TOP2score
FROMSC
WHEREt1.C#=C#
ORDER BYscoreDESC
)
ORDER BYt1.C#;
统计每门课程的学生选修人数(超过10 人的课程才统计)。要求输出课程号和选修人数,查询结果按人数
降序排列,查询结果按人数降序排列,若人数相同,按课程号升序排列
selectC#as课程号,count(*)as人数
fromsc
group byC#
order bycount(*)desc,c#
检索至少选修两门课程的学生学号
selectS#
fromsc
group bys#
havingcount(*)> =2
查询全部学生都选修的课程的课程号和课程名
selectC#,Cname
fromCourse
whereC#in(selectc#fromscgroup byc#)
查询没学过“叶平”老师讲授的任一门课程的学生姓名
selectSnamefromStudentwhereS#not in(selectS#fromCourse,Teacher,SCwhere
Course.T#=Teacher.T#andSC.C#=course.C#andTname='叶平');
查询两门以上不及格课程的同学的学号及其平均成绩
selectS#,avg(isnull(score,0))fromSCwhereS#in(selectS#fromSCwherescore<60group byS#
havingcount(*)>2)group byS#;
检索“004”课程分数小于60,按分数降序排列的同学学号
selectS#fromSCwhereC#='004'andscore<60order byscoredesc;
删除“002”同学的“001”课程的成绩
delete from Sc where S#='001'and C#='001'Student(S#,Sname,Sage,Ssex)学生表
Course(C#,Cname,T#)课程表
SC(S#,C#,score)成绩表
Teacher(T#,Tname)教师表
查询“001”课程比“002”课程成绩高的所有学生的学号;
selecta.S#from(selects#,scorefromSCwhereC#='001') a,(selects#,score
fromSCwhereC#='002') b
wherea.score>b.scoreanda.s#=b.s#;
查询平均成绩大于60分的同学的学号和平均成绩;
selectS#,avg(score)
fromsc
group byS#havingavg(score)>60;
查询所有同学的学号、姓名、选课数、总成绩;
selectStudent.S#,Student.Sname,count(SC.C#),sum(score)
fromStudentleft Outer joinSConStudent.S#=SC.S#
group byStudent.S#,Sname
查询姓“李”的老师的个数;
selectcount(distinct(Tname))
fromTeacher
whereTnamelike'李%';
查询没学过“叶平”老师课的同学的学号、姓名;
selectStudent.S#,Student.Sname
fromStudent
whereS#not in(select distinct( SC.S#)fromSC,Course,TeacherwhereSC.C#=Course.C#and
Teacher.T#=Course.T#andTeacher.Tname='叶平');
查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;
selectStudent.S#,Student.SnamefromStudent,SCwhereStudent.S#=SC.S#andSC.C#='001'and
exists(Select*fromSCasSC_2whereSC_2.S#=SC.S#andSC_2.C#='002');
查询学过“叶平”老师所教的所有课的同学的学号、姓名;
selectS#,Sname
fromStudent
whereS#in(selectS#fromSC ,Course ,TeacherwhereSC.C#=Course.C#andTeacher.T#=Course.T#
andTeacher.Tname='叶平'group byS#havingcount(SC.C#)=(selectcount(C#)fromCourse,Teacher
whereTeacher.T#=Course.T#andTname='叶平'));
查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名;
SelectS#,Snamefrom(selectStudent.S#,Student.Sname,score ,(selectscorefromSC SC_2where
SC_2.S#=Student.S#andSC_2.C#='002') score2
fromStudent,SCwhereStudent.S#=SC.S#andC#='001') S_2wherescore2
查询所有课程成绩小于60分的同学的学号、姓名;
selectS#,Sname
fromStudent
whereS#not in(selectStudent.S#fromStudent,SCwhereS.S#=SC.S#andscore>60);
查询没有学全所有课的同学的学号、姓名;
selectStudent.S#,Student.Sname
fromStudent,SC
whereStudent.S#=SC.S#group byStudent.S#,Student.Snamehavingcount(C#)
count(C#)fromCourse);
查询至少有一门课与学号为“1001”的同学所学相同的同学的学号和姓名;
selectS#,SnamefromStudent,SCwhereStudent.S#=SC.S#andC#inselectC#fromSCwhere
S#='1001';
查询至少学过学号为“001”同学所有一门课的其他同学学号和姓名;
select distinctSC.S#,Sname
fromStudent,SC
whereStudent.S#=SC.S#andC#in(selectC#fromSCwhereS#='001');
把“SC”表中“叶平”老师教的课的成绩都更改为此课程的平均成绩;
updateSCsetscore=(selectavg(SC_2.score)
fromSC SC_2
whereSC_2.C#=SC.C# )fromCourse,TeacherwhereCourse.C#=SC.C#andCourse.T#=Teacher.T#
andTeacher.Tname='叶平');
查询和“1002”号的同学学习的课程完全相同的其他同学学号和姓名;
selectS#fromSCwhereC#in(selectC#fromSCwhereS#='1002')
group byS#havingcount(*)=(selectcount(*)fromSCwhereS#='1002');
删除学习“叶平”老师课的SC表记录;
Delect SC
fromcourse ,Teacher
whereCourse.C#=SC.C#andCourse.T#=Teacher.T#andTname='叶平';
向SC表中插入一些记录,这些记录要求符合以下条件:没有上过编号“003”课程的同学学号002
号课的平均成绩;
InsertSCselectS#,'002',(Selectavg(score)
fromSCwhereC#='002')fromStudentwhereS#not in(SelectS#fromSCwhereC#='003');
按平均成绩从高到低显示所有学生的“数据库”、“企业管理”、“英语”三门的课程成绩,按如下形式显
示: 学生ID,,数据库,企业管理,英语,有效课程数,有效平均分
SELECTS#as学生ID
,(SELECTscoreFROMSCWHERESC.S#=t.S#ANDC#='004')AS数据库
,(SELECTscoreFROMSCWHERESC.S#=t.S#ANDC#='001')AS企业管理
,(SELECTscoreFROMSCWHERESC.S#=t.S#ANDC#='006')AS英语
,COUNT(*)AS有效课程数,AVG(t.score)AS平均成绩
FROMSCASt
GROUP BYS#
ORDER BYavg(t.score)
查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分
SELECTL.C#As课程ID,L.scoreAS最高分,R.scoreAS最低分
FROMSC L ,SCASR
WHEREL.C#=R.C#and
L.score=(SELECTMAX(IL.score)
FROMSCASIL,StudentASIM
WHEREL.C#=IL.C#andIM.S#=IL.S#
GROUP BYIL.C#)
AND
R.Score=(SELECTMIN(IR.score)
FROMSCASIR
WHERER.C#=IR.C#
GROUP BYIR.C#
);
按各科平均成绩从低到高和及格率的百分数从高到低顺序
SELECTt.C#AS课程号,max(course.Cname)AS课程名,isnull(AVG(score),0)AS平均成绩
,100*SUM(CASEWHENisnull(score,0)>=60THEN1ELSE0END)/COUNT(*)AS及格百分数
FROMSC T,Course
wheret.C#=course.C#
GROUP BYt.C#
ORDER BY100*SUM(CASEWHENisnull(score,0)>=60THEN1ELSE0END)/COUNT(*)DESC
查询如下课程平均成绩和及格率的百分数(用"1行"显示):企业管理(001),马克思(002),OO&UML
(003),数据库(004)
SELECTSUM(CASEWHENC#='001'THENscoreELSE0END)/SUM(CASEC#WHEN'001'THEN1
ELSE0END)AS企业管理平均分
,100*SUM(CASEWHENC#='001'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='001'THEN1ELSE0END)AS企业管理及格百分数
,SUM(CASEWHENC#='002'THENscoreELSE0END)/SUM(CASEC#WHEN'002'THEN1
ELSE0END)AS马克思平均分
,100*SUM(CASEWHENC#='002'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='002'THEN1ELSE0END)AS马克思及格百分数
,SUM(CASEWHENC#='003'THENscoreELSE0END)/SUM(CASEC#WHEN'003'THEN1
ELSE0END)ASUML平均分
,100*SUM(CASEWHENC#='003'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='003'THEN1ELSE0END)ASUML及格百分数
,SUM(CASEWHENC#='004'THENscoreELSE0END)/SUM(CASEC#WHEN'004'THEN1
ELSE0END)AS数据库平均分
,100*SUM(CASEWHENC#='004'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='004'THEN1ELSE0END)AS数据库及格百分数
FROMSC
查询不同老师所教不同课程平均分从高到低显示
SELECTmax(Z.T#)AS教师ID,MAX(Z.Tname)AS教师姓名,C.C#AS课程ID,MAX(C.Cname)AS课程
名称,AVG(Score)AS平均成绩
FROMSCAST,CourseASC ,TeacherASZ
whereT.C#=C.C#andC.T#=Z.T#
GROUP BYC.C#
ORDER BYAVG(Score)DESC
查询如下课程成绩第3名到第6名的学生成绩单:企业管理(001),马克思(002),UML(003),
数据库(004)
[学生ID],[学生姓名],企业管理,马克思,UML,数据库,平均成绩
SELECT DISTINCT top3
SC.S#As学生学号,
Student.SnameAS学生姓名,
T1.scoreAS企业管理,
T2.scoreAS马克思,
T3.scoreASUML,
T4.scoreAS数据库,
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)as总分
FROMStudent,SCLEFT JOINSCAST1
ONSC.S#=T1.S#ANDT1.C#='001'
LEFT JOINSCAST2
ONSC.S#=T2.S#ANDT2.C#='002'
LEFT JOINSCAST3
ONSC.S#=T3.S#ANDT3.C#='003'
LEFT JOINSCAST4
ONSC.S#=T4.S#ANDT4.C#='004'
WHEREstudent.S#=SC.S#and
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)
NOT IN
(SELECT
DISTINCT
TOP15WITHTIES
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)
FROMsc
LEFT JOINscAST1
ONsc.S#=T1.S#ANDT1.C#='k1'
LEFT JOINscAST2
ONsc.S#=T2.S#ANDT2.C#='k2'
LEFT JOINscAST3
ONsc.S#=T3.S#ANDT3.C#='k3'
LEFT JOINscAST4
ONsc.S#=T4.S#ANDT4.C#='k4'
ORDER BYISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)
DESC);
统计列印各科成绩,各分数段人数:课程ID,课程名称,[100-85],[85-70],[70-60],[ <60]
SELECTSC.C#as课程ID, Cnameas课程名称
,SUM(CASEWHENscoreBETWEEN85AND100THEN1ELSE0END)AS[100 - 85]
,SUM(CASEWHENscoreBETWEEN70AND85THEN1ELSE0END)AS[85 - 70]
,SUM(CASEWHENscoreBETWEEN60AND70THEN1ELSE0END)AS[70 - 60]
,SUM(CASEWHENscore<60THEN1ELSE0END)AS[60 -]
FROMSC,Course
whereSC.C#=Course.C#
GROUP BYSC.C#,Cname;
查询学生平均成绩及其名次
SELECT1+(SELECTCOUNT(distinct平均成绩)
FROM(SELECTS#,AVG(score)AS平均成绩
FROMSC
GROUP BYS#
)AST1
WHERE平均成绩>T2.平均成绩)as名次,
S#as学生学号,平均成绩
FROM(SELECTS#,AVG(score)平均成绩
FROMSC
GROUP BYS#
)AST2
ORDER BY平均成绩desc;
查询各科成绩前三名的记录:(不考虑成绩并列情况)
SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数
FROMSC t1
WHEREscoreIN(SELECT TOP3score
FROMSC
WHEREt1.C#=C#
ORDER BYscoreDESC
)
ORDER BYt1.C#;
查询每门课程被选修的学生数
selectc#,count(S#)fromscgroup byC#;
查询出只选修了一门课程的全部学生的学号和姓名
selectSC.S#,Student.Sname,count(C#)AS选课数
fromSC ,Student
whereSC.S#=Student.S#group bySC.S# ,Student.Snamehavingcount(C#)=1;
查询男生、女生人数
Selectcount(Ssex)as男生人数fromStudentgroup bySsexhavingSsex='男';
Selectcount(Ssex)as女生人数fromStudentgroup bySsexhavingSsex='女';
查询姓“张”的学生名单
SELECTSnameFROMStudentWHERESnamelike'张%';
查询同名同性学生名单,并统计同名人数
selectSname,count(*)fromStudentgroup bySnamehavingcount(*)>1;;
1981年出生的学生名单(注:Student表中Sage列的类型是datetime)
selectSname,CONVERT(char(11),DATEPART(year,Sage))asage
fromstudent
whereCONVERT(char(11),DATEPART(year,Sage))='1981';
查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列
SelectC#,Avg(score)fromSCgroup byC#order byAvg(score),C#DESC;
查询平均成绩大于85的所有学生的学号、姓名和平均成绩
selectSname,SC.S# ,avg(score)
fromStudent,SC
whereStudent.S#=SC.S#group bySC.S#,Snamehavingavg(score)>85;
查询课程名称为“数据库”,且分数低于60的学生姓名和分数
SelectSname,isnull(score,0)
fromStudent,SC,Course
whereSC.S#=Student.S#andSC.C#=Course.C#andCourse.Cname='数据库'andscore<60;
查询所有学生的选课情况;
SELECTSC.S#,SC.C#,Sname,Cname
FROMSC,Student,Course
whereSC.S#=Student.S#andSC.C#=Course.C# ;
查询任何一门课程成绩在70分以上的姓名、课程名称和分数;
SELECT distinctstudent.S#,student.Sname,SC.C#,SC.score
FROMstudent,Sc
WHERESC.score>=70ANDSC.S#=student.S#;
查询不及格的课程,并按课程号从大到小排列
selectc#fromscwherescor e<60order byC# ;
查询课程编号为003且课程成绩在80分以上的学生的学号和姓名;
selectSC.S#,Student.SnamefromSC,StudentwhereSC.S#=Student.S#andScore>80and
C#='003';
求选了课程的学生人数
selectcount(*)fromsc;
查询选修“叶平”老师所授课程的学生中,成绩最高的学生姓名及其成绩
selectStudent.Sname,score
fromStudent,SC,Course C,Teacher
whereStudent.S#=SC.S#andSC.C#=C.C#andC.T#=Teacher.T#andTeacher.Tname='叶平'and
SC.score=(selectmax(score)fromSCwhereC#=C.C# );
查询各个课程及相应的选修人数
selectcount(*)fromscgroup byC#;
查询不同课程成绩相同的学生的学号、课程号、学生成绩
select distinctA.S#,B.scorefromSC A ,SC BwhereA.Score=B.ScoreandA.C#<>B.C# ;
查询每门功成绩最好的前两名
SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数
FROMSC t1
WHEREscoreIN(SELECT TOP2score
FROMSC
WHEREt1.C#=C#
ORDER BYscoreDESC
)
ORDER BYt1.C#;
统计每门课程的学生选修人数(超过10人的课程才统计)。要求输出课程号和选修人数,查询结果按人数
降序排列,查询结果按人数降序排列,若人数相同,按课程号升序排列
selectC#as课程号,count(*)as人数
fromsc
group byC#
order bycount(*)desc,c#
检索至少选修两门课程的学生学号
selectS#
fromsc
group bys#
havingcount(*)> =2
查询全部学生都选修的课程的课程号和课程名
selectC#,Cname
fromCourse
whereC#in(selectc#fromscgroup byc#)
查询没学过“叶平”老师讲授的任一门课程的学生姓名
selectSnamefromStudentwhereS#not in(selectS#fromCourse,Teacher,SCwhere
Course.T#=Teacher.T#andSC.C#=course.C#andTname='叶平');
查询两门以上不及格课程的同学的学号及其平均成绩
selectS#,avg(isnull(score,0))fromSCwhereS#in(selectS#fromSCwherescore<60group byS#
havingcount(*)>2)group byS#;
检索“004”课程分数小于60,按分数降序排列的同学学号
selectS#fromSCwhereC#='004'andscore<60order byscoredesc;
删除“002”同学的“001”课程的成绩
delete fromScwhereS#='001'andC#='001'
Student(S#,Sname,Sage,Ssex)学生表
Course(C#,Cname,T#)课程表
SC(S#,C#,score)成绩表
Teacher(T#,Tname)教师表
查询“001”课程比“002”课程成绩高的所有学生的学号;
selecta.S#from(selects#,scorefromSCwhereC#='001') a,(selects#,score
fromSCwhereC#='002') b
wherea.score>b.scoreanda.s#=b.s#;
查询平均成绩大于60分的同学的学号和平均成绩;
selectS#,avg(score)
fromsc
group byS#havingavg(score)>60;
查询所有同学的学号、姓名、选课数、总成绩;
selectStudent.S#,Student.Sname,count(SC.C#),sum(score)
fromStudentleft Outer joinSConStudent.S#=SC.S#
group byStudent.S#,Sname
查询姓“李”的老师的个数;
selectcount(distinct(Tname))
fromTeacher
whereTnamelike'李%';
查询没学过“叶平”老师课的同学的学号、姓名;
selectStudent.S#,Student.Sname
fromStudent
whereS#not in(select distinct( SC.S#)fromSC,Course,TeacherwhereSC.C#=Course.C#and
Teacher.T#=Course.T#andTeacher.Tname='叶平');
查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;
selectStudent.S#,Student.SnamefromStudent,SCwhereStudent.S#=SC.S#andSC.C#='001'and
exists(Select*fromSCasSC_2whereSC_2.S#=SC.S#andSC_2.C#='002');
查询学过“叶平”老师所教的所有课的同学的学号、姓名;
selectS#,Sname
fromStudent
whereS#in(selectS#fromSC ,Course ,TeacherwhereSC.C#=Course.C#andTeacher.T#=Course.T#
andTeacher.Tname='叶平'group byS#havingcount(SC.C#)=(selectcount(C#)fromCourse,Teacher
whereTeacher.T#=Course.T#andTname='叶平'));
查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名;
SelectS#,Snamefrom(selectStudent.S#,Student.Sname,score ,(selectscorefromSC SC_2where
SC_2.S#=Student.S#andSC_2.C#='002') score2
fromStudent,SCwhereStudent.S#=SC.S#andC#='001') S_2wherescore2
查询所有课程成绩小于60分的同学的学号、姓名;
selectS#,Sname
fromStudent
whereS#not in(selectStudent.S#fromStudent,SCwhereS.S#=SC.S#andscore>60);
查询没有学全所有课的同学的学号、姓名;
selectStudent.S#,Student.Sname
fromStudent,SC
whereStudent.S#=SC.S#group byStudent.S#,Student.Snamehavingcount(C#)
count(C#)fromCourse);
查询至少有一门课与学号为“1001”的同学所学相同的同学的学号和姓名;
selectS#,SnamefromStudent,SCwhereStudent.S#=SC.S#andC#inselectC#fromSCwhere
S#='1001';
查询至少学过学号为“001”同学所有一门课的其他同学学号和姓名;
select distinctSC.S#,Sname
fromStudent,SC
whereStudent.S#=SC.S#andC#in(selectC#fromSCwhereS#='001');
把“SC”表中“叶平”老师教的课的成绩都更改为此课程的平均成绩;
updateSCsetscore=(selectavg(SC_2.score)
fromSC SC_2
whereSC_2.C#=SC.C# )fromCourse,TeacherwhereCourse.C#=SC.C#andCourse.T#=Teacher.T#
andTeacher.Tname='叶平');
查询和“1002”号的同学学习的课程完全相同的其他同学学号和姓名;
selectS#fromSCwhereC#in(selectC#fromSCwhereS#='1002')
group byS#havingcount(*)=(selectcount(*)fromSCwhereS#='1002');
删除学习“叶平”老师课的SC表记录;
Delect SC
fromcourse ,Teacher
whereCourse.C#=SC.C#andCourse.T#=Teacher.T#andTname='叶平';
向SC表中插入一些记录,这些记录要求符合以下条件:没有上过编号“003”课程的同学学号002
号课的平均成绩;
InsertSCselectS#,'002',(Selectavg(score)
fromSCwhereC#='002')fromStudentwhereS#not in(SelectS#fromSCwhereC#='003');
按平均成绩从高到低显示所有学生的“数据库”、“企业管理”、“英语”三门的课程成绩,按如下形式显
示: 学生ID,,数据库,企业管理,英语,有效课程数,有效平均分
SELECTS#as学生ID
,(SELECTscoreFROMSCWHERESC.S#=t.S#ANDC#='004')AS数据库
,(SELECTscoreFROMSCWHERESC.S#=t.S#ANDC#='001')AS企业管理
,(SELECTscoreFROMSCWHERESC.S#=t.S#ANDC#='006')AS英语
,COUNT(*)AS有效课程数,AVG(t.score)AS平均成绩
FROMSCASt
GROUP BYS#
ORDER BYavg(t.score)
查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分
SELECTL.C#As课程ID,L.scoreAS最高分,R.scoreAS最低分
FROMSC L ,SCASR
WHEREL.C#=R.C#and
L.score=(SELECTMAX(IL.score)
FROMSCASIL,StudentASIM
WHEREL.C#=IL.C#andIM.S#=IL.S#
GROUP BYIL.C#)
AND
R.Score=(SELECTMIN(IR.score)
FROMSCASIR
WHERER.C#=IR.C#
GROUP BYIR.C#
);
按各科平均成绩从低到高和及格率的百分数从高到低顺序
SELECTt.C#AS课程号,max(course.Cname)AS课程名,isnull(AVG(score),0)AS平均成绩
,100*SUM(CASEWHENisnull(score,0)>=60THEN1ELSE0END)/COUNT(*)AS及格百分数
FROMSC T,Course
wheret.C#=course.C#
GROUP BYt.C#
ORDER BY100*SUM(CASEWHENisnull(score,0)>=60THEN1ELSE0END)/COUNT(*)DESC
查询如下课程平均成绩和及格率的百分数(用"1行"显示):企业管理(001),马克思(002),OO&UML
(003),数据库(004)
SELECTSUM(CASEWHENC#='001'THENscoreELSE0END)/SUM(CASEC#WHEN'001'THEN1
ELSE0END)AS企业管理平均分
,100*SUM(CASEWHENC#='001'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='001'THEN1ELSE0END)AS企业管理及格百分数
,SUM(CASEWHENC#='002'THENscoreELSE0END)/SUM(CASEC#WHEN'002'THEN1
ELSE0END)AS马克思平均分
,100*SUM(CASEWHENC#='002'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='002'THEN1ELSE0END)AS马克思及格百分数
,SUM(CASEWHENC#='003'THENscoreELSE0END)/SUM(CASEC#WHEN'003'THEN1
ELSE0END)ASUML平均分
,100*SUM(CASEWHENC#='003'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='003'THEN1ELSE0END)ASUML及格百分数
,SUM(CASEWHENC#='004'THENscoreELSE0END)/SUM(CASEC#WHEN'004'THEN1
ELSE0END)AS数据库平均分
,100*SUM(CASEWHENC#='004'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHEN
C#='004'THEN1ELSE0END)AS数据库及格百分数
FROMSC
查询不同老师所教不同课程平均分从高到低显示
SELECTmax(Z.T#)AS教师ID,MAX(Z.Tname)AS教师姓名,C.C#AS课程ID,MAX(C.Cname)AS课程
名称,AVG(Score)AS平均成绩
FROMSCAST,CourseASC ,TeacherASZ
whereT.C#=C.C#andC.T#=Z.T#
GROUP BYC.C#
ORDER BYAVG(Score)DESC
查询如下课程成绩第3名到第6名的学生成绩单:企业管理(001),马克思(002),UML(003),
数据库(004)
[学生ID],[学生姓名],企业管理,马克思,UML,数据库,平均成绩
SELECT DISTINCT top3
SC.S#As学生学号,
Student.SnameAS学生姓名,
T1.scoreAS企业管理,
T2.scoreAS马克思,
T3.scoreASUML,
T4.scoreAS数据库,
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)as总分
FROMStudent,SCLEFT JOINSCAST1
ONSC.S#=T1.S#ANDT1.C#='001'
LEFT JOINSCAST2
ONSC.S#=T2.S#ANDT2.C#='002'
LEFT JOINSCAST3
ONSC.S#=T3.S#ANDT3.C#='003'
LEFT JOINSCAST4
ONSC.S#=T4.S#ANDT4.C#='004'
WHEREstudent.S#=SC.S#and
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)
NOT IN
(SELECT
DISTINCT
TOP15WITHTIES
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)
FROMsc
LEFT JOINscAST1
ONsc.S#=T1.S#ANDT1.C#='k1'
LEFT JOINscAST2
ONsc.S#=T2.S#ANDT2.C#='k2'
LEFT JOINscAST3
ONsc.S#=T3.S#ANDT3.C#='k3'
LEFT JOINscAST4
ONsc.S#=T4.S#ANDT4.C#='k4'
ORDER BYISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)
DESC);
统计列印各科成绩,各分数段人数:课程ID,课程名称,[100-85],[85-70],[70-60],[ <60]
SELECTSC.C#as课程ID, Cnameas课程名称
,SUM(CASEWHENscoreBETWEEN85AND100THEN1ELSE0END)AS[100 - 85]
,SUM(CASEWHENscoreBETWEEN70AND85THEN1ELSE0END)AS[85 - 70]
,SUM(CASEWHENscoreBETWEEN60AND70THEN1ELSE0END)AS[70 - 60]
,SUM(CASEWHENscore<60THEN1ELSE0END)AS[60 -]
FROMSC,Course
whereSC.C#=Course.C#
GROUP BYSC.C#,Cname;
查询学生平均成绩及其名次
SELECT1+(SELECTCOUNT(distinct平均成绩)
FROM(SELECTS#,AVG(score)AS平均成绩
FROMSC
GROUP BYS#
)AST1
WHERE平均成绩>T2.平均成绩)as名次,
S#as学生学号,平均成绩
FROM(SELECTS#,AVG(score)平均成绩
FROMSC
GROUP BYS#
)AST2
ORDER BY平均成绩desc;
查询各科成绩前三名的记录:(不考虑成绩并列情况)
SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数
FROMSC t1
WHEREscoreIN(SELECT TOP3score
FROMSC
WHEREt1.C#=C#
ORDER BYscoreDESC
)
ORDER BYt1.C#;
查询每门课程被选修的学生数
selectc#,count(S#)fromscgroup byC#;
查询出只选修了一门课程的全部学生的学号和姓名
selectSC.S#,Student.Sname,count(C#)AS选课数
fromSC ,Student
whereSC.S#=Student.S#group bySC.S# ,Student.Snamehavingcount(C#)=1;
查询男生、女生人数
Selectcount(Ssex)as男生人数fromStudentgroup bySsexhavingSsex='男';
Selectcount(Ssex)as女生人数fromStudentgroup bySsexhavingSsex='女';
查询姓“张”的学生名单
SELECTSnameFROMStudentWHERESnamelike'张%';
查询同名同性学生名单,并统计同名人数
selectSname,count(*)fromStudentgroup bySnamehavingcount(*)>1;;
1981年出生的学生名单(注:Student表中Sage列的类型是datetime)
selectSname,CONVERT(char(11),DATEPART(year,Sage))asage
fromstudent
whereCONVERT(char(11),DATEPART(year,Sage))='1981';
查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列
SelectC#,Avg(score)fromSCgroup byC#order byAvg(score),C#DESC;
查询平均成绩大于85的所有学生的学号、姓名和平均成绩
selectSname,SC.S# ,avg(score)
fromStudent,SC
whereStudent.S#=SC.S#group bySC.S#,Snamehavingavg(score)>85;
查询课程名称为“数据库”,且分数低于60的学生姓名和分数
SelectSname,isnull(score,0)
fromStudent,SC,Course
whereSC.S#=Student.S#andSC.C#=Course.C#andCourse.Cname='数据库'andscore<60;
查询所有学生的选课情况;
SELECTSC.S#,SC.C#,Sname,Cname
FROMSC,Student,Course
whereSC.S#=Student.S#andSC.C#=Course.C# ;
查询任何一门课程成绩在70分以上的姓名、课程名称和分数;
SELECT distinctstudent.S#,student.Sname,SC.C#,SC.score
FROMstudent,Sc
WHERESC.score>=70ANDSC.S#=student.S#;
查询不及格的课程,并按课程号从大到小排列
selectc#fromscwherescor e<60order byC# ;
查询课程编号为003且课程成绩在80分以上的学生的学号和姓名;
selectSC.S#,Student.SnamefromSC,StudentwhereSC.S#=Student.S#andScore>80and
C#='003';
求选了课程的学生人数
selectcount(*)fromsc;
查询选修“叶平”老师所授课程的学生中,成绩最高的学生姓名及其成绩
selectStudent.Sname,score
fromStudent,SC,Course C,Teacher
whereStudent.S#=SC.S#andSC.C#=C.C#andC.T#=Teacher.T#andTeacher.Tname='叶平'and
SC.score=(selectmax(score)fromSCwhereC#=C.C# );
查询各个课程及相应的选修人数
selectcount(*)fromscgroup byC#;
查询不同课程成绩相同的学生的学号、课程号、学生成绩
select distinctA.S#,B.scorefromSC A ,SC BwhereA.Score=B.ScoreandA.C#<>B.C# ;
查询每门功成绩最好的前两名
SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数
FROMSC t1
WHEREscoreIN(SELECT TOP2score
FROMSC
WHEREt1.C#=C#
ORDER BYscoreDESC
)
ORDER BYt1.C#;
统计每门课程的学生选修人数(超过10人的课程才统计)。要求输出课程号和选修人数,查询结果按人数
降序排列,查询结果按人数降序排列,若人数相同,按课程号升序排列
selectC#as课程号,count(*)as人数
fromsc
group byC#
order bycount(*)desc,c#
检索至少选修两门课程的学生学号
selectS#
fromsc
group bys#
havingcount(*)> =2
查询全部学生都选修的课程的课程号和课程名
selectC#,Cname
fromCourse
whereC#in(selectc#fromscgroup byc#)
查询没学过“叶平”老师讲授的任一门课程的学生姓名
selectSnamefromStudentwhereS#not in(selectS#fromCourse,Teacher,SCwhere
Course.T#=Teacher.T#andSC.C#=course.C#andTname='叶平');
查询两门以上不及格课程的同学的学号及其平均成绩
selectS#,avg(isnull(score,0))fromSCwhereS#in(selectS#fromSCwherescore<60group byS#
havingcount(*)>2)group byS#;
检索“004”课程分数小于60,按分数降序排列的同学学号
selectS#fromSCwhereC#='004'andscore<60order byscoredesc;
删除“002”同学的“001”课程的成绩
delete fromScwhereS#='001'andC#='001'