实验三(2) SQL查询(排序、集函数和分组子句的应用)

 

试验目的:
一、学习查询结果的排序
二、学习使用集函数的方法,完成统计

等查询。
三、学习使用分组子句

 

一、学习查询结果的排序

1、查询全体学生信息,结果按照年龄降

序排序

select * 
from student
order by sage desc

2、查询学生选修情况,结果先按照课程

号升序排序,再按成绩降序排序

select * 
from sc
order by cno,grade desc

思考题:查询学生姓名,及其选修的课

程名和成绩,结果先按照课程名升序排

序,再按成绩降序排序

1、排序是对查询结果的排序,排序方法

有两种,升序(默认 asc)和降序

(desc)。
2、当排序的属性有多个时,优先排序的

放在前面,依次列出,中间用逗号隔开


3、当查询结果是多个表时,利用连接查

询(where 条件内把共同列相等),然

后对查询结果排序。

 

二、集函数的应用
1、查询student表内学生人数
select count(sno)
from student

select count(*)
from student

2、查询有选修课程的学生人数
select count(distinct sno)
from sc

3、查询3号课程的成绩总分
select sum(grade)
from sc
where cno='3'

4、查询学生年龄和
select sum(sage)
from student

5、查询学生200215122所选修的课程的

平均分
select avg(grade)
from sc
where sno='200215122'

6、求3号课程的最高分
select max(grade)
from sc
where cno = '3'

练习:

1、查询有几门选修课被选修
select count(distinct cno)
from sc

2、查询学生中男生人数

select count(sno)
from student
where ssex = '男'

3、查询学生200215121所选修的课程成

绩总分
select sum(grade)
from sc
where sno='200215121'

4、查询3号课程的平均分
select avg(grade)
from sc
where cno='3'
思考题:

  1、查询学生中各年龄段人数

select sage,count(sno)
from student
group by sage

2、查询3号课程的平均分和最高分
select avg(grade) 平均分,max(grade)

最高分
from sc
where cno='3'
总结:

  1、集函数count(属性名)计算个数,

注意distinct 属性名的应用,取消重复

的行。属性名列表可以是多个用字符串

连接(+)。
  2、sum(),avg()这两个是对数值型属

性进行的统计操作。
  3、max(),min()根据属性(数值型的

或字符型的都可以)选择最大的或最小

的。

 

三、分组group by子句的应用

1、查询课程号及相应的选修人数
select cno,count(*)
from sc
group by cno

注意:列出结果一个是cno,一个是集函

数统计的结果,不能单独列出不参与分

组的属性。

练习:
1、查询男生和女生人数(查询性别及其

对应人数) 
select ssex,count(*)
from student
group by ssex

2、查询各系名及其各系对应人数
select sdept,count(*)
from student 
group by sdept

3、查询课程名及其平均分
select cname,avg(grade)
from course,sc
where course.cno=sc.cno
group by cname

思考题:
1、查询课程号和课程名,及其选修人数
select sc.cno,cname,count(*)
from sc,course
where sc.cno=course.cno
group by sc.cno,cname

2、查询学号、姓名,及其选修的课程名

平均分

 

 

代码:

  1. select count(distinct sno)  
  2. from sc  
  3.   
  4. select sage,count(sno)  
  5. from student  
  6. group by sage  
  7.   
  8. select sum(grade)  
  9. from sc  
  10. where cno='3'  
  11.   
  12. select sum(grade)  
  13. from sc  
  14. where sno='200215121'  
  15.   
  16. select avg(grade)  
  17. from sc  
  18. where sno='200215122'  
  19.   
  20. select avg(grade) 平均分,max(grade) 最高分  
  21. from sc  
  22. where cno='3'  
  23.   
  24. select * from student  
  25.   
  26. --字符串相加  
  27. select '学号='+sno+'课程号='+cno  
  28. from sc  
  29.   
  30. select max(sno)  
  31. from student  
  32. select * from student  
  33.   
  34. select cno,count(*)  
  35. from sc  
  36. group by cno  
  37.   
  38. select sc.cno,cname,count(*)  
  39. from sc,course  
  40. where sc.cno=course.cno  
  41. group by sc.cno,cname  
  42.   
  43. select cname,avg(grade)  
  44. from course,sc  
  45. where course.cno=sc.cno  
  46. group by cname  

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章