1

私はこのテーブルを持っています:

DebitDate | DebitTypeID | DebitPrice | DebitQuantity
----------------------------------------------------
40577       1             50           3
40577       1             100          1
40577       2             75           2
40578       1             50           2
40578       2             150          2

単一のクエリ(可能な場合)で取得したいのは、日付、debit_id、total_sum_of_same_debit、how_many_debits_per_dayです。

したがって、上記の例から、次のようになります。

40577, 1, (50*3)+(100*1), 2 (because 40577 has 1 and 2 so total of 2 debits per this day)
40577, 2, (75*2), 2 (because 40577 has 1 and 2 so total of 2 debits per this day)
40578, 1, (50*2), 2 (because 40578 has 1 and 2 so total of 2 debits per this day)
40578, 2, (150*2), 2 (because 40578 has 1 and 2 so total of 2 debits per this day)

だから私はこのSQLクエリを持っています:

SELECT      DebitDate, DebitTypeID, SUM(DebitPrice*DebitQuantity) AS TotalSum
FROM        DebitsList
GROUP BY    DebitDate, DebitTypeID, DebitPrice, DebitQuantity

そして今、私は問題を抱えており、必要な最後の情報のカウントをどこに置くべきかわかりません。

4

2 に答える 2

1

この新しい列を取得するには、相関サブクエリが必要です。また、GROUP BY 句を機能させるには、DebitPrice と DebitQuantityを削除する必要があります。

SELECT   DebitDate,
         DebitTypeID,
         SUM(DebitPrice*DebitQuantity) AS TotalSum,
         (   select Count(distinct E.DebitTypeID)
             from DebitsList E
             where E.DebitDate=D.DebitDate) as CountDebits
FROM     DebitsList D
GROUP BY DebitDate, DebitTypeID
于 2011-02-03T10:11:53.150 に答える
0

これはあなたを助けることができると思います。

SELECT      DebitDate,  SUM(DebitPrice*DebitQuantity) AS TotalSum, Count(DebitDate) as DebitDateCount
FROM        DebitsList where DebitTypeID = 1
GROUP BY    DebitDate
于 2011-02-03T10:19:16.900 に答える