我有一张"Customers
“桌。
它有一个列名"CreatedDate
",意思是它是客户的加入日期。
我想计算出从当前日期到截止日期的1-5年、6-10年、11-15年的客户数量,如下所示
Years No of Customer
0-5 200
6-10 500
11-15 100
详细地说,如果一个客户创建的日期是"5-5-2010“,那么从当前日期起的0到5年之间就应该是这样。
如果创制日期为"5-5-2006“,则应从当前日期起在6-10年之间。
发布于 2013-10-21 06:33:10
尝尝这个
SELECT '0-5' as [Years],COUNT(Customer) as [No of Customers] FROM dbo.Customers WHERE DATEDIFF(YY,CreatedDate,GETDATE()) <=5
UNION
SELECT '6-10' as [Years],COUNT(Customer) as [No of Customers] FROM dbo.Customers WHERE DATEDIFF(YY,CreatedDate,GETDATE()) >=5 AND DATEDIFF(YY,CreatedDate,GETDATE()) <=10
UNION
SELECT '11-15' as [Years],COUNT(Customer) as [No of Customers] FROM dbo.Customers WHERE DATEDIFF(YY,CreatedDate,GETDATE()) >=10 AND DATEDIFF(YY,CreatedDate,GETDATE()) <=15
发布于 2013-10-21 06:18:29
使用此查询:
With s as(
SELECT custid,CASE WHEN FLOOR(DATEDIFF(DAY,CREATEDATE,GETDATE())/365)>=1
AND
FLOOR(DATEDIFF(DAY,CREATEDATE,GETDATE())/365)<=5 THEN '1-5'
WHEN
FLOOR(DATEDIFF(DAY,CREATEDATE,GETDATE())/365)>=6
AND
FLOOR(DATEDIFF(DAY,CREATEDATE,GETDATE())/365)<=10 THEN '6-10' END as 'd'
FROM TABLE)
select count(custid),d
from s
group by d
https://stackoverflow.com/questions/19487147
复制相似问题