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

妙用SQL Server聚合函數和子查詢迭代求和

編輯:關於SqlServer

先看看下面的表和其中的數據:

t_product

圖1

該表有兩個字段:xh和price, 其中xh是主索引字段,現在要得到如下的查詢結果:

圖2

從上面的查詢結果可以看出,totalprice字段值的規則是從第1條記錄到當前記錄的price之和。如第3條記錄的totalprice字段的值是10 + 25 + 36 = 71。

現在要通過t_product表中的數據生成圖2所示的查詢結果。可能會有很多讀者想到使用循環和游標,不過這種方式效率並不高,尤其在記錄非常多的情況。

從圖2的查詢結果分析可知,這個結果仍然是求和的操作,只是並不是對所有的記錄求和,也不是分組求和,而是使用迭代的方式進行求和,求和的公式如下:

當前記錄的totalprice值 = 當前記錄的price值 + 上一條記錄的totalprice值

上一條記錄的totalprice值也可看成是當前記錄以前所有記錄的price值之和。因此,可以對每一條記錄進行求和(使用sum函數),不過要求出當前記錄及以前的記錄的price之和,如下面的SQL語句:

select a.xh, a.price,
(select sum(price) from t_product b where b.xh <= a.xh) as totalprice
from t_product a

從上面的SQL語句可以看出,使用了一個子查詢來求totalprice字段的值,基本原理就是根據當前記錄的xh值(a.xh)來計算從當前記錄往前所有記錄的price值之和,b.xh表示子查詢當前的xh值,在子查詢中,a.xh相當於常量。上面的SQL語句的查詢結果和圖2完全一樣。如果我們的需求是不包含當前記錄的price值,也就是說,計算totalprice字段的公式如下:

當前記錄的totalprice值 = 上一條當前記錄的price值 + 上一條記錄的totalprice值

第一條記錄的totalprice值就是當前記錄的price值,查詢t_product表的結果如圖3所示。

圖3

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