mysql - 多个条件并按区间排序的的查询如何高效的解决
黄舟
黄舟 2017-04-17 10:58:55
[MySQL讨论组]

查询一个结果集,靠三个条件来排序,取排名靠前的100个作为结果

第一个条件:

“距离”,按三个区间排:1km以内,1-10km,10km以外

第二个条件:

“最后活跃时间”,按三个区间排:1-8小时,8-24小时,24小时以外

第三个条件:

“最后使用指定功能的时间”:按时间从新到旧

假设,第一个条件“1km”以内的有300个(大于100),那么就要看这300个中,第二个条件“最后活跃时间”在“1-8小时”的有多少个,若小于100,则看“8-24小时”的有多少个,若与“1-8小时”的数量一共大于100,则按第三个条件“最后使用指定功能的时间”从新到旧将这些结果排序,并取前100个。

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回复(0)
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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