实验五 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(*)
f
相关文档:
一、SQL SERVER 和ACCESS的数据导入导出
常规的数据导入导出:
使用DTS向导迁移你的Access数据到SQL Server,你可以使用这些步骤:
○1在SQL SERVER企业管理器中的Tools(工具)菜单上,选择Data Transformation
○2Services(数据转换服务),然后选择 czdImport Dat ......
如果你经常遇到下面的问题,你就要考虑使用SQL Server的模板来写规范的SQL语句了:
SQL初学者。
经常忘记常用的DML或是DDL SQL 语句。
在多人开发维护的SQL中,每个人都有自己的SQL习惯,没有一套统一的规范。
在SQL Server Management Studio中,已经给大家提供了很多常用的现成SQL规范模板。
SQL Server Management ......
在sql server 2005里,根据数据库性能动态构建索引。
数据库设计好后,系统上线运动一个周期后,数据库性能瓶颈突现出来,这个时间,需要一种根据性能,来动态构建索引,提高查询效率。
--过程优化SQL
&nb ......
对于SQL我也学习了,但是真正用到的时候才知道很多东西还不太理解,在网上看了一下,这篇文章中讲的很好,所以拿来和大家分享一下:
SQL JOIN 的用法
关于sql语句中的连接(join)关键字,是较为常用而又不太容易理解的关键字,下面这个例子给出了一个简单的解释 --建表table1,table2:
create table table1(id int,n ......
declare @str varchar(8000),@sql varchar(8000)
set @str=''
select @str=@str+','+name from syscolumns WHERE ID=OBJECT_ID('表名') AND NAME!='要排除的列名'
set @str=stuff(@str,1,1,'')
set @sql='select '+@str+' from 表名'
exec (@sql) ......