SQL程式設計例項:Access資料庫,兩張表的統計,count、sum聚合函式的使用,iif的使用,group by的使用
阿新 • • 發佈:2019-01-25
使用工具:
FineReport報表設計器,Access資料庫
需求描述:
有兩張表,訂單表和訂單明細表
1、訂單表結構:
2、訂單明細表結構:
目的:根據這兩張表做出下面的一張表
分析:
1、因為在訂單明細裡訂單ID可能出現多次,所以一定要先把訂單ID去重,否則兩張表join的時候,訂單ID就會有重複的,這時用count函式求訂單數量時就會出錯了
所以先將訂單明細表按訂單ID進行分組:
(select 訂單ID,sum(數量*單價*(1-折扣)) as 訂單銷量 from 訂單明細 group by 訂單ID)
然後再兩張表join:
2、接下來就是需要對以上求出的這張”總表“進行按年份和月份分組,count(訂單ID)求訂單數量,sum聚合函式進行帶有條件的求和來求已付訂單數量等。select 單子.訂單ID,訂購年份,訂購月份,訂單銷量,是否已付 from (SELECT 訂單ID,year("訂購日期") as 訂購年份,month("訂購日期") as 訂購月份,是否已付 from 訂單) as 單子, (select 訂單ID,sum(數量*單價*(1-折扣)) as 訂單銷量 from 訂單明細 group by 訂單ID) as 詳情 where 單子.訂單ID=詳情.訂單ID
解答:
select 訂購年份,訂購月份,count(訂單ID) as 訂單數量,sum(訂單銷量*iif(是否已付=1,1,0)) as 已付訂單數量,sum(訂單銷量) as 銷量 from (select 單子.訂單ID,訂購年份,訂購月份,訂單銷量,是否已付 from (SELECT 訂單ID,year("訂購日期") as 訂購年份,month("訂購日期") as 訂購月份,是否已付 from 訂單) as 單子, (select 訂單ID,sum(數量*單價*(1-折扣)) as 訂單銷量 from 訂單明細 group by 訂單ID) as 詳情 where 單子.訂單ID=詳情.訂單ID ) where 訂購年份 =${year} group by 訂購年份,訂購月份
部分解釋:
1、year,month是帆軟設計器自帶函式,例如,year函式作用是將2014-5-3取得年份2014
2、iif(是否已付=1,1,0)是Access資料庫條件判斷,作用是,如果是否已付=1,則返回1,否則返回0
3、${year}是傳過來的引數