资源描述:
《数据库sql查询语句练习》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、查询语句1、查询“001”课程比“002”课程成绩高的所有学生的学号;selecta.S#from(selects#,scorefromSCwhereC#='001')asa,(selects#,scorefromSCwhereC#='002')asbwherea.score>b.scoreanda.s#=b.s#2、查询平均成绩大于60分的同学的学号和平均成绩;selectS#,avg(score)fromscgroupbyS#havingavg(score)>603、查询所有同学的学号、姓名、选课数、总成绩;selectStudent.S#,S
2、tudent.Sname,count(SC.C#),sum(score)fromStudentleftjoinSConStudent.S#=SC.S#groupbyStudent.S#,Sname4、查询姓“李”的老师的个数;selectcount(distinct(Tname))fromTeacherwhereTnamelike'李%'5、查询没学过“张三”老师课的同学的学号、姓名;selectStudent.S#,Student.SnamefromStudentwhereS#notin(selectdistinct(SC.S#)fromSC,C
3、ourse,TeacherwhereSC.C#=Course.C#andTeacher.T#=Course.T#andTeacher.Tname='张三')6、查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;selectStudent.S#,Student.SnamefromStudent,SCwhereStudent.S#=SC.S#andSC.C#='001'andexists(Select*fromSCasSC_2whereSC_2.S#=SC.S#andSC_2.C#='002')7、查询学过“张三”老师所教的所有课的同学
4、的学号、姓名;selectS#,SnamefromStudentwhereS#in(selectS#fromSC,Course,TeacherwhereSC.C#=Course.C#andTeacher.T#=Course.T#andTeacher.Tname='张三'groupbyS#havingcount(SC.C#)=(selectcount(C#)fromCourse,TeacherwhereTeacher.T#=Course.T#andTname='张三'))8、查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名
5、;SelectS#,Snamefrom(selectStudent.S#,Student.Sname,score,(selectscorefromSCSC_2whereSC_2.S#=Student.S#andSC_2.C#='002')asscore2fromStudent,SCwhereStudent.S#=SC.S#andC#='001')S_2wherescore26、Student,SCwhereS.S#=SC.S#andscore>60)10、查询没有学全所有课的同学的学号、姓名;selectStudent.S#,Student.SnamefromStudent,SCwhereStudent.S#=SC.S#groupbyStudent.S#,Student.Snamehavingcount(C#)<(selectcount(C#)fromCourse)11、查询至少有一门课与学号为“1001”的同学所学相同的同学的学号和姓名;selectS#,SnamefromStudent,SCwhereStudent.
7、S#=SC.S#andC#in(selectC#fromSCwhereS#='1001')12、查询至少学过学号为“001”同学所有一门课的其他同学学号和姓名;selectdistinctSC.S#,SnamefromStudent,SCwhereStudent.S#=SC.S#andC#in(selectC#fromSCwhereS#='001')13、把“SC”表中“张三”老师教的课的成绩都更改为此课程的平均成绩;updateSCsetscore=(selectavg(SC_2.score)fromSCSC_2whereSC_2.C#=SC.C
8、#)fromCourse,TeacherwhereCourse.C#=SC.C#andCourse.T#=Teacher.