1. 程式人生 > >SQL程式設計例項:Access資料庫,兩張表的統計,count、sum聚合函式的使用,iif的使用,group by的使用

SQL程式設計例項:Access資料庫,兩張表的統計,count、sum聚合函式的使用,iif的使用,group by的使用

使用工具:

FineReport報表設計器,Access資料庫

需求描述:

有兩張表,訂單表和訂單明細表

1、訂單表結構:


2、訂單明細表結構:


目的:根據這兩張表做出下面的一張表


分析:

1、因為在訂單明細裡訂單ID可能出現多次,所以一定要先把訂單ID去重,否則兩張表join的時候,訂單ID就會有重複的,這時用count函式求訂單數量時就會出錯了

所以先將訂單明細表按訂單ID進行分組:

(select 訂單ID,sum(數量*單價*(1-折扣)) as 訂單銷量 from 訂單明細 group by 訂單ID)
然後再兩張表join:
select 單子.訂單ID,訂購年份,訂購月份,訂單銷量,是否已付 from

(SELECT 訂單ID,year("訂購日期") as 訂購年份,month("訂購日期") as 訂購月份,是否已付 from 訂單) as 單子,
(select 訂單ID,sum(數量*單價*(1-折扣)) as 訂單銷量 from 訂單明細 group by 訂單ID) as 詳情 

where 單子.訂單ID=詳情.訂單ID
2、接下來就是需要對以上求出的這張”總表“進行按年份和月份分組,count(訂單ID)求訂單數量,sum聚合函式進行帶有條件的求和來求已付訂單數量等。

解答:

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}是傳過來的引數