我使用的代码根据 where 子句中的日期为我提供了正确的信息。我想在其他日期获得相同的信息。所以现在我必须自己更改日期并运行代码,将其复制/粘贴到其他地方,然后以新的日期重新开始。如果我想要一年中每一天的信息,那需要做很多工作。是否可以自动更改 where 子句中的日期,最好或最简单的方法是什么?
Select t4.Count, t4.Status
From(
SELECT count(l.VoerID) as Count, l.Datum, l.Status, l.LogID
FROM (
SELECT k.VoerID, k.Datum, MAX(k.LogID) AS LogID
FROM DB.LogStatus k
Where Datum < '2013-07-01'
GROUP BY k.VoerID
) m
JOIN DB.LogStatus l
ON l.VoerID = m.VoerID AND l.LogID = m.LogID
Where status in ('B','IN1','IN2''V','Reserv')
Group by Status
)t4
编辑:
原始表(在一个 VoerID 上选择)(表由数千个 VoerID 组成)
LogID 数据 UserID 状态 时间 VoerID
1299772 2013-04-17 259 N 14:09:11 50174
1319774 2013-05-23 68 B 11:19:17 50174
1320038 2013-05-23 197 IN1 16:53:30 50174
1322002 2013-05-28 68 IN2 09:22:32 50174
1325052 2013-05-31 161 G 09:00:59 50174
1325166 2013-05-31 10 400 09:15:12 50174
1325182 2013-05-31 10 V 09:30:07 50174
1325208 2013-05-31 10 V 09:45:06 50174
1325406 2013-05-31 10 保留 11:45:06 50174
1325522 2013-05-31 10 保留 12:15:06 50174
1325954 2013-05-31 10 保留 15:15:13 50174
1328474 2013-06-05 10 保留 13:15:06 50174
1329230 2013-06-06 10 保留 09:45:03 50174
1329244 2013-06-06 10 存档时间 10:00:08 50174
1329268 2013-06-06 10 存档时间 10:15:08 50174
1330286 2013-06-07 10 存档时间 10:15:06 50174
我现在想知道 VoerID 在第一个月的状态是什么。所以在 2013-05-01 状态 = N,在 2013-06-01 状态 = 保留,从 2013-07-01 开始存档。
以上是针对一个 VoerID。我想计算每个月初的 VoerID 数量、下个月第一天之前的每个最后一个 LOGID 以及每个状态的数量
最后,如果我得到我想在 MSExcel 中将其编辑为交叉表和图表的信息:
2013 年 1 月 1 日 2013 年 1 月 2 日 2013 年 1 月 3 日 2013 年 1 月 4 日 2013 年 1 月 5 日
20 22 24 26 28
B 23 21,5 20 18,5 17
IN1 12 15 18 21 24
IN2 15 7 14 18 25
V 800 1000 1200 1400 1600
预留 50 63 76 89 102
存档 100000 101220 102440 103660 104880