QlikView报表显示连续若干个月内活跃用户的数量

php中文网
发布: 2016-06-07 15:57:11
原创
1118人浏览过

之前有朋友提到了这样一个需求,要计算三年中每年都有销售记录的客户量,只有最近两年有销售纪录的客户量(假如某个用户2012年和2014年都有记录,在2013年没有则不计算在内),以及最近一年的新增客户数量。这里大概描述一下我的思路。 Sales表有两个字段Id, Y

之前有朋友提到了这样一个需求,要计算三年中每年都有销售记录的客户量,只有最近两年有销售纪录的客户量(假如某个用户2012年和2014年都有记录,在2013年没有则不计算在内),以及最近一年的新增客户数量。这里大概描述一下我的思路。

Sales表有两个字段Id, Year,要求除上述结果需要Group by Id,然后算Count(DISTINCT Year)的值要等于Min(Year)和Max(Year)的差+1,比如下面关于记录:

Year, Id
2014, 14
2013, 14
2012, 14
登录后复制

Max(Year)是2014,Min(Year)是2012,Count(DISTINCT Year)是3,则这个Id是连续三年都有记录的。下面的记录则是连续两年都有记录的:

2013,12
2014,12
登录后复制

Max(Year)是2014,Min(Year)是2013,Count(DISTINCT Year)是2。下面的记录则是最近一年的新客户:

2014,17
登录后复制

Max(Year)是2014,Min(Year)是2014,Count(DISTINCT Year)是1,。

具体代码是这样的:

//导入数据
Customer:
LOAD
	Year,
	Id
From
	../QVD/Customer.csv;

//获得最近三年中,每个Id出现的最大年份和最小年份,以及不同Year的数量
Frequency20140609Temp:
LOAD
	Id as Id0609Temp,
	Min(Year) as MinYear0609Temp,
	Max(Year) as MaxYear0609Temp,
	Count(DISTINCT Year) as CountYear0609Temp
Resident
	Customer
Where
	Year>=Year(Now())-2
Group By
	Id;

//取出Id出现的最大年份减去最小年份+1等于该Id出现的不同年份的数量
Frequency20140609:
LOAD
	Id0609Temp as Id0609,
	MinYear0609Temp as MinYear0609,
	CountYear0609Temp as CountYear0609
Resident
	Frequency20140609Temp
Where
	MaxYear0609Temp-MinYear0609Temp + 1 = CountYear0609Temp
	AND MaxYear0609Temp=Year(Now());//最大年份需要是今年,要不然可能是去年以前连续两年都有销售记录的Id
登录后复制

下面是图表的Dimension,Expression和Chart:

\

\

 

\

如图所示,最近一年才有记录的是4个Id,连续两年有销售纪录的是2个Id,连续三年有销售纪录的是8个Id。

下面用一些数据测试一下我的结果,首先在Customer.csv中插入如下数据:

2012,18
2013,18
2012,19
2014,19
2013,20
(PS: 上面的这些Id在之前数据源中都不存在,是这次新加的)
登录后复制

按照我现在的逻辑,增加上面Id为18,19,20的记录都不会导致图表发生变化,如下所示:

\

再增加如下数据,

2014,21
2013,22
2014,22
2012,23
2013,23
2014,23
登录后复制

则上面图表中的三项数据都会+1,如下所示:

\

各位看官,假如文中有错还望不吝赐教!感谢感谢!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号