全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1696
推到 Plurk!
推到 Facebook!

SQL問題-如何讓同一筆資料加總後只顯示一次

 
diane123
一般會員


發表:1
回覆:0
積分:0
註冊:2006-12-07

發送簡訊給我
#1 引用回覆 回覆 發表時間:2006-12-07 05:06:24 IP:218.170.xxx.xxx 未訂閱
以下為我寫的SQL語法:
SELECT A.SupplierID, S.SupplierAttribName,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '01') AS Amount01,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '02') AS Amount02,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '03') AS Amount03,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '04') AS Amount04,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '05') AS Amount05,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '06') AS Amount06,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '07') AS Amount07,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '08') AS Amount08,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '09') AS Amount09,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '10') AS Amount10,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '11') AS Amount11,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear AND X.PurchaseMonth = '12') AS Amount12,
(SELECT SUM(X.PurchaseAmount - X.PurchaseReturnAmount)
FROM PurchaseAnalyst X
WHERE X.CompanyID = :CompanyID
AND X.SupplierID = A.SupplierID
AND X.PurchaseYear = A.PurchaseYear) AS Amount
FROM PurchaseAnalyst A, Supplier S
WHERE A.CompanyID = :CompanyID AND A.PurchaseYear = :PurchaseYear
AND A.SupplierID = S.SupplierID
AND A.SupplierID >= :BeginSupplierID AND A.SupplierID <= :EndSupplierID
ORDER BY A.SupplierID
----------------------------------------------------------------------------------------------------------
我想依據 SupplierID 來做群組分類,讓資料在各個月份加總後,只顯示一次,但是目前報表會依據SupplierID的筆數重複顯示!
這個問題讓我很困擾,麻煩高手幫忙解決,而且很急~
資料表的設計如下:
CompanyID PurchaseYear PurchaseMonth SupplierID ProductID PurchaseQuantity PurchaseAmount
PurchaseReturnQuantity PurchaseReturnAmount
此資料表為一個進貨分析檔!
系統時間:2024-05-01 12:14:15
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!