程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> 例說SQLServer2008聚合函數

例說SQLServer2008聚合函數

編輯:關於SqlServer

       創建tb_Students表並插入3條測試數據。
    ?

    1 2 3 4 5 6 7 CREATE TABLE tb_Students( id int NOT NULL IDENTITY, name NVARCHAR(16) NOT NULL, age int NOT NULL, PRIMARY KEY(id)) INSERT INTO tb_Students(name,age) VALUES('tiana',15),('yardi',20),('zhangyun',18)

      1 SUM()函數

      返回某列值的和。

      例:

      SQL查詢:

    ?

    1 SELECT SUM(age) FROM tb_Students WHERE age>15

      執行結果:

    例說SQLServer2008聚合函數    三聯

      說明:

      返回年齡大於15的學生的年齡之和:120+18=38。

      2 COUNT()函數

      返回某列的行數。

      例:

      SQL查詢:

    ?

    1 SELECT COUNT(*) FROM tb_Students WHERE age>15

      執行結果:

      說明:

      返回年齡大於15的學生記錄的行數。

      當然這裡查詢中可以使用“COUNT(id)”,“COUNT(name)”,“COUNT(age)”,結果一致。

      3 AVG()函數

      返回某列的平均值。

      例:

      SQL查詢:

    ?

    1 SELECT AVG(age) FROM tb_Students WHERE age>15

      執行結果:

      4 MAX()函數

      返回某列的最大值。

      例:

      SQL查詢:

    ?

    1 SELECT MAX(age) FROM tb_Students WHERE age>15

      執行結果:

      5 MIN()函數

      返回某列的最小值。

      例:

      SQL查詢:

    ?

    1 SELECT MIN(age) FROM tb_Students WHERE age>15

      執行結果:

      6 聚合函數與GROUP BY子句一起使用

      SUM(),COUNT(),AVG(),MAX(),MIN()函數與GROUP BY子句一起使用時,可以用來計算每個分組的總和,記錄總數,平均值,最大值,最小值。

      例:

      創建表tb_Class並插入8條測試數據。

      SQL查詢:

    ?

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 CREATE TABLE tb_Class( classid int NOT NULL IDENTITY, classname NVARCHAR(16) NOT NULL, students int NOT NULL, teacher NVARCHAR(16) NOT NULL, PRIMARY KEY(classid)) INSERT INTO tb_Class(classname,students,teacher) VALUES ('1班',25,'yl'),('2班',18,'wsp'),('3班',24,'yl'),('4班',25,'zhy'), ('5班',22,'wsp'),('6班',25,'yl'),('7班',20,'zhy'), ('8班',22,'wsp') SELECT SUM(students) FROM tb_Class GROUP BY teacher SELECT COUNT(students) FROM tb_Class GROUP BY teacher SELECT AVG(students) FROM tb_Class GROUP BY teacher SELECT MAX(students) FROM tb_Class GROUP BY teacher SELECT MIN(students) FROM tb_Class GROUP BY teacher

      執行結果:

      7 聚集不同的值

      例:

      SQL查詢:

    ?

    1 SELECT COUNT(DISTINCT teacher) FROM tb_Class

      執行結果:

      說明: 聚集函數與DISTINCT子句一起使用時,可以去除掉重復的記錄後再使用聚集函數進行運算。

      實例中的查詢查詢出班級表中教師的數目。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved