新的与重复使用的用户,数月作为列MySQL
我有一个订单表,每个订单都有一个时间戳字段以及用户_ID:
CREATE TABLE order(
id BIGINT,
created TIMESTAMP,
user_id INT
PRIMARY KEY(id)
)
我正在尝试获得这样的东西,在其中我每月获得了新的和经常性用户的计数。用户在整个月内都是新的,他们首次购买并在此之后每次购买。
客户类型 | 月1个 | 月2 | 个月3 | |
---|---|---|---|---|
新的 | 计数 | 计数 | 计数 | |
反复 | 计数 | 计数 | 肯定 | |
到目前为止,
SELECT 'New' AS 'Customer Type',
SUM(CASE WHEN MONTH(created) = 1 THEN 1 ELSE 0 END) month_1,
SUM(CASE WHEN MONTH(created) = 2 THEN 1 ELSE 0 END) month_2,
SUM(CASE WHEN MONTH(created) = 3 THEN 1 ELSE 0 END) month_3
FROM order
HAVING MONTH(MIN(created))
我已经计划在不在(Min(Min(创建))语句中使用联盟的连接,但我敢 有一个更好的方法
。
I have a order table where I have a timestamp field for each order as well as the user_id:
CREATE TABLE order(
id BIGINT,
created TIMESTAMP,
user_id INT
PRIMARY KEY(id)
)
I'm trying to get something like this where I get the count of new and recurrent users for each month. A user is new for the whole month they made their first purchase and recurrent every purchase after that.
Customer Type | month 1 | month 2 | month 3 | |
---|---|---|---|---|
new | count | count | count | |
recurrent | count | count | count | |
So far I have this:
SELECT 'New' AS 'Customer Type',
SUM(CASE WHEN MONTH(created) = 1 THEN 1 ELSE 0 END) month_1,
SUM(CASE WHEN MONTH(created) = 2 THEN 1 ELSE 0 END) month_2,
SUM(CASE WHEN MONTH(created) = 3 THEN 1 ELSE 0 END) month_3
FROM order
HAVING MONTH(MIN(created))
I was planning on using a UNION for the recurrent with a NOT IN (MIN(MONTH(created)) statement but i'm sure there's a better approach to this.
Any help will be greatly appreciated!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论