-1

私はレポートを作成しています。出力は次のようになります (例):

['11/2012', 5, 2, 0]
['10/2012', 7, 1, 0]
['09/2012', 2, 3, 0]
['08/2012', 0, 0, 1]
['07/2012', 0, 2, 1]
['06/2012', 2, 1, 0]
['05/2012', 3, 1, 1]
['04/2012', 2, 2, 1]
['03/2012', 5, 0, 0]
['02/2012', 7, 1, 0]
['01/2012', 2, 0, 0]
['12/2011', 3, 0, 1]

月の部分については、実際の月を取得し、1 年前のリストを取得する必要があります。私はこのコードでこれを行いました:

<%
    DataAtual_PeriodoInicial= Now
    DataFinal_PeriodoInicial= DateAdd("m", -13, Now)
    DO WHILE Datediff("m", DataAtual_PeriodoInicial, DataFinal_PeriodoInicial) <> 0
%>
    ['<% Response.Write(Right("0" & Month(DataAtual_PeriodoInicial), 2)) %>/<% Response.Write(Year(DataAtual_PeriodoInicial)) %>', X, Y, Z]<br>
<%
    DataAtual_PeriodoInicial= DateAdd("m", -1, DataAtual_PeriodoInicial)
    LOOP
%>

したがって、これは生成しています:

['11/2012', X, Y, Z]
['10/2012', X, Y, Z]
['09/2012', X, Y, Z]
['08/2012', X, Y, Z]
['07/2012', X, Y, Z]
['06/2012', X, Y, Z]
['05/2012', X, Y, Z]
['04/2012', X, Y, Z]
['03/2012', X, Y, Z]
['02/2012', X, Y, Z]
['01/2012', X, Y, Z]
['12/2011', X, Y, Z]

ここで、X、Y、Z の代わりにいくつかの数値をスローする必要があります。次のようなデータを含むテーブルがあります。

11  2012    X
10  2012    X
10  2012    X
10  2012    X
10  2012    Y
10  2012    Y
10  2012    Z
10  2012    Z
10  2012    Z
9   2012    X
9   2012    X
9   2012    X
9   2012    Y
9   2012    Z
9   2012    Z
8   2012    X
8   2012    X
8   2012    Y
8   2012    Y
8   2012    Y
8   2012    Y
8   2012    Y
...

そして、私はこの選択から始めます:

SELECT
    datepart(month,SentDate) AS Mes,
    datepart(year,SentDate) AS Ano,
    EventType
FROM
    SomeTable
ORDER BY
    SentDate DESC

私はいくつかのグループ化を試みましたが、成功しませんでした。ある種のカウントが必要ですか?和?そして、この質問の上部にあるような出力を得るにはどうすればよいですか?

ありがとう!

4

1 に答える 1

2

これを試して

SELECT
    datepart(month,SentDate) AS Mes,
    datepart(year,SentDate) AS Ano,
    sum(CASE WHEN EventType = 'X' THEN 1 ELSE 0 END ) X,
    sum(CASE WHEN EventType = 'Y' THEN 1 ELSE 0 END ) Y,
    sum(CASE WHEN EventType = 'Z' THEN 1 ELSE 0 END ) Z
FROM
    SomeTable
GROUP BY
    datepart(month,SentDate),
    datepart(year,SentDate)
ORDER BY
    Ano DESC,
    Mes DESC
    SentDate DESC

http://sqlfiddle.com/#!3/93a11/23/0のデモ


PIVOT テーブルを使用することもできます

SELECT * FROM
  (
  SELECT 
    datepart(month,SentDate) AS Mes,
    datepart(year,SentDate) AS Ano,
    EventType
  FROM 
    SomeTable
 ) grouped
PIVOT (COUNT(eventType) for EventType in ([X],[Y],[Z])) AS pivoted
ORDER BY
  Ano DESC,
  Mes DESC

http://sqlfiddle.com/#!3/93a11/16/0のデモ

于 2012-11-13T14:06:50.567 に答える