小白菜S 2022-03-04 14:27 采纳率: 85.7%
浏览 42

MySQL 千万级 分组怎么优化

表中有 id、姓名、生日三个字段,数据千万级的。需要查询每个年龄有多少人。整个查询不能超过1秒。请问哪位可以回答下

  • 写回答

2条回答 默认 最新

  • 嗷呜的善泽融 2022-03-04 15:22
    关注

    如果是oracle,就直接在年龄上面建立位图索引。
    Mysql的话,因为id是不重复的,你可以在id上面建唯一索引
    查询的使用使用count(),因为你在id建立了唯一索引,所以count()就会根据age分组,然后使用id来统计,这样就会快很多

    如下:

    select count(*)  from t_user group by age
    
    
    评论

报告相同问题?

问题事件

  • 修改了问题 3月4日
  • 创建了问题 3月4日

悬赏问题

  • ¥50 易语言把MYSQL数据库中的数据添加至组合框
  • ¥20 求数据集和代码#有偿答复
  • ¥15 关于下拉菜单选项关联的问题
  • ¥20 java-OJ-健康体检
  • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
  • ¥15 使用phpstudy在云服务器上搭建个人网站
  • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
  • ¥15 vue3+express部署到nginx
  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况