根据日期分组统计如何查询速度快

30天内120W数据做分组查询

CREATE TABLE `tablex` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `ctime` bigint(20) DEFAULT NULL COMMENT '',
  PRIMARY KEY (`id`),
  KEY `idx_time` (`ctime`),
) ENGINE=InnoDB AUTO_INCREMENT=1568014 DEFAULT CHARSET=utf8mb4 

 select (FROM_UNIXTIME(ctime,''%'Y-'%'m-'%'d')) t, COUNT(DISTINCT uid) num from `tablex` where `ctime` >= 1659484800 and `ctime` < 1662076800 group by `t`

Laravel

《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
最佳答案

建议对 ctime 做个缓存字段 cdate,类型是 date 。然后对其设置 index。

那么查询的时候,尝试如下SQL呢:

select `cdate`, COUNT(DISTINCT uid) num from `tablex` where `ctime` >= 1659484800 and `ctime` < 1662076800 group by `cdate`
2年前 评论
讨论数量: 3

你这个uid没有索引吧,还有group by 和 having在一起会更好吧

2年前 评论
哪吒的狗腿子 (楼主) 2年前

建议对 ctime 做个缓存字段 cdate,类型是 date 。然后对其设置 index。

那么查询的时候,尝试如下SQL呢:

select `cdate`, COUNT(DISTINCT uid) num from `tablex` where `ctime` >= 1659484800 and `ctime` < 1662076800 group by `cdate`
2年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!