码迷,mamicode.com
首页 > 数据库 > 详细

数据库中最简单最原始的聚合函数

时间:2015-11-05 00:36:17      阅读:171      评论:0      收藏:0      [点我收藏+]

标签:

    当走在嘈杂的城市中时,什么能让我们变得冷静呢?心声向我述说了一些,“简单”不一定就真的简单,它是相对的,当我们长大了,想要保持儿时的单纯,我想只能在梦中由心所发了,因为现实让我们都变了,要想重新找回曾经的东西,可能真的很难。

    就像我将要说的五个比较简单的函数,但它真的简单吗?只有你自己认真去浏览一遍才有可能读懂其中的话意,所有的问题都有一个突破口,当我们找到时,问题的简单之处油然而生,反之,再简单的问题都是你心中的永远挥之不去的阴影。所以说这些函数简不简单谁也说不准,就像世间万物均以相生相克存在着一样,

     可能有人就会问了:那什么是聚合函数,又该怎么去使用它呢?

     专家解析:一般在做统计分析的时候需要使用聚合函数

    当我们需要计算时,我们首先想到的应该就是Sum() “求总和”、AVG()  ”求平均“、COUNT()  “求总记录“;那比较的函数就是MAX() "最大值" 和MIN() “最小值”。

     既然我们都知道了它们的作用了,就来看看怎么运用并实现其功能的吧!!!
       01.SUM()函数

          --查询每个年级的总学时数,并按照升序排列

select gradeid as 年级编号,SUM(classhour) as 总学时数
from Subject
group by gradeid
order by 总学时数 asc


       02.AVG()函数

select AVG(studentresult) as 平均分  from  Result

            --查询每个参加考试的学员平均分

select studentno as 学号,AVG(studentresult) as 平均分
from Result
group by studentno

           --查询每门课程的平均分,并按照降序排列

select subjectid as 课程编号,AVG(studentresult) as 平均分
from Result
group by SubjectId
order by 平均分 desc

            
          --查询每年级学生的平均年龄:

select gradeid as 年级,AVG(DATEDIFF(YY,birthday,getdate())) as 平均年龄
from student
group by GradeId
--查询参加年级考试的学生中,平均分及格的学生记录,按照降序排列
select studentno as 学号,avg(StudentResult) as 平均分
from Result
group by StudentNo
having  avg(StudentResult)>60
order by 平均分 desc

       --查询考试时间为-9-9课程的及格平均分
       --课程编号   所有课程平均分

select subjectid  as 课程编号,AVG(studentresult) as 所有课程平均分
from Result
where ExamDate>=2009-9-9 and ExamDate<2009-9-10
group by subjectid
having AVG(StudentResult)>60

 


        03.MAX()函数

select MAX(studentresult) as 最高分 from Result


        04.MIN()函数

  select min(studentresult) as 最高分 from Result

 

        05.COUNT()函数

           COUNT():统计一张表中总共有多少条数据

例如:

          --查询每年级学时数超过的课程数

select gradeid as 年级编号,COUNT(subjectid) as 课程总数
from Subject
where ClassHour>=50
group by GradeId

         --统计至少有一次不及格的学生学号和次数。

select studentno as 学号,COUNT(studentresult) as 次数
from Result
where StudentResult<60
group by studentno

       --查询每个年级包含北京的学生总数

select gradeid as 年级,COUNT(studentno) as 总人数
from student
where Address like %北京%
group by GradeId

     

最后需要记住五个函数都要遵守的注意事项

       --如果语句中有group by关键字,那么select后只能跟group by后出现的列,或者是聚合函数
        --max() min() count(),sum(),avg()

    

       最后,希望我的作品能够让您满意,如有不足之处,请不要吝啬你的建议,只有这样我的作品才能令你满意;因为一次的缺漏永远会给下一次补充、让其变得更好

 

数据库中最简单最原始的聚合函数

标签:

原文地址:http://www.cnblogs.com/bdpsc/p/4937883.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!