SQL編程執行個體:Access資料庫,兩張表的統計,count、sum彙總函式的使用,iif的使用,group by的使用

來源:互聯網
上載者:User

使用工具:

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


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.