首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Sql查询,根据加入日期获取客户数量

Sql查询,根据加入日期获取客户数量
EN

Stack Overflow用户
提问于 2013-10-21 05:55:47
回答 2查看 386关注 0票数 2

我有一张"Customers“桌。

它有一个列名"CreatedDate",意思是它是客户的加入日期。

我想计算出从当前日期到截止日期的1-5年、6-10年、11-15年的客户数量,如下所示

代码语言:javascript
运行
复制
Years         No of Customer
0-5           200
6-10          500
11-15         100

详细地说,如果一个客户创建的日期是"5-5-2010“,那么从当前日期起的0到5年之间就应该是这样。

如果创制日期为"5-5-2006“,则应从当前日期起在6-10年之间。

EN

回答 2

Stack Overflow用户

发布于 2013-10-21 06:33:10

尝尝这个

代码语言:javascript
运行
复制
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
票数 1
EN

Stack Overflow用户

发布于 2013-10-21 06:18:29

使用此查询:

代码语言:javascript
运行
复制
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
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19487147

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档