如果要包含每个客户的最近日期,则可以使用max(orderdate) over(partition by customerId)
:
select customer.CustomerID,
o.OrderDate,
max(o.orderdate) over(partition by customer.customerid) mostrecentorder
from Customers as customer
join Orders as o
on customer.CustomerID = o.customerid;
请参阅SQL Fiddle with Demo。
您的完整代码将类似于:
declare @start DATE = '2012-01-01';
declare @end DATE = DATEADD(dd,-(DAY(GETDATE())-1),GETDATE());
DECLARE @cols AS NVARCHAR(MAX),
@query AS NVARCHAR(MAX);
with months (dateList)
AS
(
SELECT @start
UNION ALL
SELECT DATEADD(month,1,dateList)
from months
where DATEADD(month,1,dateList)<=@end
)
select dateList
into #tempDates
from months
option (maxrecursion 0);
select @cols = STUFF((SELECT distinct ',' + QUOTENAME(convert(varchar(10), datelist, 120))
from #tempDates
FOR XML PATH(''), TYPE
).value('.', 'NVARCHAR(MAX)')
,1,1,'')
set @query = '
select *
from
(
select customer.CustomerID,
o.OrderDate,
max(o.orderdate) over(partition by customer.customerid) mostrecentorder
from Customers as customer
join Orders as o
on customer.CustomerID = o.customerid
) x
pivot
(
Count(OrderDate)
for OrderDate in ('+ @cols + ')
)y'
execute sp_executesql @query
请参阅SQL Fiddle with Demo。
如果您想按月显示数据(您在上面的结果中显示),那么您可以稍微更改代码以使用DATENAME:
declare @start DATE = '2012-01-01';
declare @end DATE = DATEADD(dd,-(DAY(GETDATE())-1),GETDATE());
DECLARE @cols AS NVARCHAR(MAX),
@query AS NVARCHAR(MAX);
with months (dateList)
AS
(
SELECT @start
UNION ALL
SELECT DATEADD(month,1,dateList)
from months
where DATEADD(month,1,dateList)<=@end
)
select dateList
into #tempDates
from months
option (maxrecursion 0);
select @cols = STUFF((SELECT ',' + QUOTENAME(mth)
from
(
select datepart(month, datelist) so, datename(month, datelist) mth
from #tempDates
) d
group by so, mth
order by so, mth
FOR XML PATH(''), TYPE
).value('.', 'NVARCHAR(MAX)')
,1,1,'')
set @query = '
select customerId, '+@cols+', mostrecentorder
from
(
select customer.CustomerID,
datename(month, o.OrderDate) orderDate,
max(o.orderdate) over(partition by customer.customerid) mostrecentorder
from Customers as customer
join Orders as o
on customer.CustomerID = o.customerid
) x
pivot
(
Count(OrderDate)
for OrderDate in ('+ @cols + ')
)y'
execute sp_executesql @query;
请参阅SQL Fiddle with Demo。这将给出一个结果:
| CUSTOMERID | JANUARY | FEBRUARY | MARCH | APRIL | MAY | JUNE | JULY | AUGUST | SEPTEMBER | OCTOBER | NOVEMBER | DECEMBER | MOSTRECENTORDER |
|------------|---------|----------|-------|-------|-----|------|------|--------|-----------|---------|----------|----------|----------------------------|
| 3 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | May, 03 2013 00:00:00+0000 |
| 2 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | May, 13 2013 00:00:00+0000 |
| 1 | 1 | 2 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | May, 23 2013 00:00:00+0000 |