2017-08-29 10 views
1

合計が0の行を削除することはできますか?SQL - 同じGroup Byを持つ0に等しい合計を探すことはできますか?

+-----------+--------------+ 
| Subledger | ActualAmount | 
+-----------+--------------+ 
| WWE12  | -25775  | 
| WWE12  | -217   | 
| WWE12  | -43   | 
| WWE12  | 260   | 
| WWE12  | 48994  | 
+-----------+--------------+ 

および所望の結果は次のようになります:ここ

表である

+-----------+--------------+ 
| Subledger | ActualAmount | 
+-----------+--------------+ 
| WWE12  | -217   | 
| WWE12  | -43   | 
| WWE12  | 260   | 
+-----------+--------------+ 

この上の任意の助けを大幅に高く評価されています。

ありがとうございました!

+2

結果セットから5行のうちの2行を削除するロジックが不明です。これらの行は、*合計*にどのように関連していますか?あなたの質問を編集してください。 –

+0

あなたが望む結果でそれらの3つを合計すると、答えは0になります。それはすべて私が見たい-25775と48994ではありません – Jomari

+0

あなたは私を失ってしまいました! – Strawberry

答えて

0

これは私が和は3つの値で構成されていたことを事前に知っていたので、非常に不自然ですが、とにかく...

SELECT x.* 
    FROM 
    (SELECT DISTINCT GROUP_CONCAT(DISTINCT c.actualamount ORDER BY c.actualamount) members 
      , SUM(DISTINCT c.actualamount) total 
     FROM my_table a 
     JOIN my_table b 
      ON b.actualamount NOT IN (a.actualamount) 
     JOIN my_table c 
      ON c.actualamount NOT IN (a.actualamount,b.actualamount) 
     GROUP 
      BY a.actualamount 
      , b.actualamount 
     HAVING total = 0 
    ) n 
    JOIN my_table x 
    ON FIND_IN_SET(actualamount,members) > 0; 
0

この試してください:あなたが削除することができます

SELECT ROW_NUMBER() OVER (ORDER BY ActualAmount DESC) rw , 
     * 
INTO #Negative 
FROM your_table 
WHERE ActualAmount < 0; 

SELECT ROW_NUMBER() OVER (ORDER BY (SELECT 1 
            )) rw , 
     * 
INTO #Positive 
FROM your_table 
WHERE ActualAmount > 0; 


CREATE TABLE #FinalTable 
    (
     Subledger NVARCHAR(50) NULL , 
     ActualAmount INT NULL 
    ); 

DECLARE @NCounterMax INT= (SELECT COUNT(*) 
          FROM #Negative 
         ); 
DECLARE @PCounterMax INT= (SELECT COUNT(*) 
          FROM #Positive 
         ) , 
    @NC INT= 1 , 
    @PC INT= 1 , 
    @amount INT= 0 , 
    @amount2 INT= 0 , 
    @subledger NVARCHAR(50) , 
    @countinue BIT = 1 , 
    @SumAmount INT= 0; 
WHILE (@PC <= @PCounterMax) 
    BEGIN 
     SELECT @amount = ActualAmount , 
       @subledger = Subledger 
     FROM #Positive 
     WHERE rw = @PC; 
     INSERT INTO #FinalTable 
     VALUES (@subledger, @amount); 
     SET @SumAmount = @amount; 
     PRINT @amount; 
     WHILE (@NC <= @NCounterMax) 
      BEGIN 
       SELECT @amount2 = ActualAmount , 
         @subledger = Subledger 
       FROM #Negative 
       WHERE rw = @NC; 
       INSERT INTO #FinalTable 
       VALUES (@subledger, @amount2); 
       SET @SumAmount = @SumAmount + @amount2; 
       IF (@SumAmount = 0) 
        BEGIN 
         SET @countinue = 0; 
         BREAK; 
        END; 
       SET @NC = @NC + 1; 
      END; 
     IF (@countinue = 0) 
      BREAK; 
     DELETE #FinalTable; 
     SET @PC = @PC + 1; 
    END; 
SELECT * 
FROM #FinalTable; 

DROP TABLE #Negative; 
DROP TABLE #Positive; 
DROP TABLE #FinalTable; 

#FinalTableあなたのテーブルのレコード。

関連する問題