首页 新闻 会员 周边 捐助

mysql order by 排序没有按照预期执行

0
悬赏园豆:200 [已解决问题] 解决于 2022-08-01 19:56

期望使用 ' SUBSTRING_INDEX( GROUP_CONCAT( package.behaviors_num_today ORDER BY match_time desc), ',', 1 ) AS behaviors_num_today' 的结果进行排序.

但是实际上order by 的值是当前id最大的behaviors_num_today.

SELECT 
    * 
FROM
    (
    SELECT
        package.ip  as ip,
        SUBSTRING_INDEX( GROUP_CONCAT( package.behaviors_num_today ORDER BY match_time desc), ',', 1 ) AS behaviors_num_today
    FROM
        ip_statistical_package package
        LEFT JOIN ip_persona i ON package.ip = i.ip
        LEFT JOIN intelligence_source_tag ist ON i.ip = ist.ip
        LEFT JOIN tag t ON i.ip = t.ip
        LEFT JOIN intelligence_source_tag_name istn ON istn.source_tag_id = ist.id 
    GROUP BY
        package.ip
    ) a order by behaviors_num_today desc
    LIMIT 100 OFFSET 0;
lbr617的主页 lbr617 | 初学一级 | 园豆:27
提问于:2022-08-01 17:49
< >
分享
最佳答案
0

SUBSTRING_INDEX 将结果变为字符类型了无法进行排序.

可以通过 order by behaviors_num_today+0 desc 的方式解决

lbr617 | 初学一级 |园豆:27 | 2022-08-01 19:56
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册