2016-12-02 135 views
1

我有如下数据:SQL Server的SQL语句 - 更新记录

enter image description here

我需要使用column id, region, company, dept, subdept and amountsepend更新Matching_idMatching_Type。逻辑是:

Sum AmountSepend by Region, Company, Dept and SubDept。如果总金额为0,那么Matching_Type是'匹配',而Matching_id是匹配记录的ID的组合,否则'不匹配'且Matching_id是ID。 ** SUM表示不论AmountSepend是正数还是负数,对于相同条件的所有记录的总数。

另一个重要的标准是,如果该事务是单个记录,通过各地区分组意总计数,公司,DEPT和SubDept为1,则相配的类型不匹配,Matching_UID是ID不管AmountSepend是0或正/负值。实例ID 8

下面是输出:

enter image description here

这里的表和数据的脚本

CREATE TABLE [dbo].[StackoverflowQuest](
[id] [int] NOT NULL, 
[Region] [varchar](50) NULL, 
[Company] [varchar](50) NULL, 
[Dept] [varchar](50) NULL, 
[SubDept] [varchar](50) NULL, 
[AmountSepend] [float] NULL, 
[Matching_id] [varchar](100) NULL, 
[Matching_Type] [varchar](100) NULL 
) ON [PRIMARY] 

我怎么能取得这样的结果?任何帮助/暗示将不胜感激

+0

你还在寻找解决方案吗? – andrews

回答

0
CREATE TABLE #Table(Id INT,Region VARCHAR(100),Company INT,Dept INT,SubDept  
INT,AmtSpend INT,MatchingId VARCHAR(100),MatchingType VARCHAR(100)) 

INSERT INTO #Table(Id ,Region ,Company , Dept ,SubDept ,AmtSpend) 
SELECT 1,'NAM',12378,1,NULL,900 UNION ALL 
SELECT 2,'NAM',12378,1,NULL,-900 UNION ALL 
SELECT 3,'NAM',12370,1,23,1000 UNION ALL 
SELECT 4,'ASA',1234,9,12,5000 UNION ALL 
SELECT 5,'NAM',12370,1,23,-1000 UNION ALL 
SELECT 6,'ASA',1234,9,12,800 UNION ALL 
SELECT 7,'ASA',1234,9,12,-600 UNION ALL 
SELECT 8,'ASA',12311,6,NULL,200 

UPDATE #Table SET MatchingId = MatchIds,MatchingType = 'Match' 
FROM 
(
    SELECT T2.Company,STUFF((SELECT ',' + CAST(T3.Id AS VARCHAR) FROM #Table  
    T3 WHERE T2.Company = T3.Company FOR XML PATH('')),1,1,'') MatchIds 
    FROM #Table T2 
    JOIN 
    (
    SELECT T1.Company Company,SUM(T1.AmtSpend) Total 
    FROM #Table T1 
    GROUP BY T1.Company 
    HAVING SUM(T1.AmtSpend) = 0 
)A ON A.Company = T2.Company 
    GROUP BY T2.Company 
) A 
WHERE A.Company = #Table.Company 


UPDATE #Table SET MatchingId = CAST(Id AS VARCHAR),MatchingType = 'Not 
Match' WHERE ISNULL(MatchingId,'') = '' 

SELECT * FROM #Table 
+0

你确定你的代码能正常工作,当相同部门的负数分成2个或更多的记录时不是900 vs -900而是900 vs(-600和-300)?您只能将2个值添加到MatchIds列中。 – andrews

+0

查看上面的用户需要的输出。他们不需要总和负值。他们只检查正值和负值。 – Mansoor

+0

“按地区,公司,部门和子部门划分的总金额” - 对我来说,总和意味着相同标准的所有记录的总和,而不是仅为2的总和。只有1个正面和1个负面记录仅仅是一个简化的情况一个普通的任务。但是,让OP澄清。 – andrews