windghost817
windghost817
采纳率57.9%
2018-06-26 05:46

mysql5.7子查询排序不生效的问题。

10
已采纳

在网上查了到说子查询中增加 limit 会生效。 但是实际尝试后发现结果顺序还是随机的,只不过需要执行多次后才会变化。
求助让子查询排序生效的办法。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

3条回答

  • Lei_Da_Gou Lei_Da_Gou 3年前

    mysql5.7会自动优化掉子查询中的order by,但是子查询后加了limit 0,10000后就防止了mysql的自动优化,我测试排序是可以的啊。
    SELECT temp.* FROM(
    SELECT * FROM t_kaoqin
    WHERE p_id=1 AND TO_DAYS(t_kaoqin.kq_time)=TO_DAYS(NOW())
    ORDER BY kq_time DESC LIMIT 0,10000

            ) AS temp GROUP BY temp.user_id 
    
    点赞 3 评论 复制链接分享
  • qq_37312838 马尔斯的蓝色 3年前

    sql里面的子查询不需要排序

    点赞 评论 复制链接分享
  • qq_40160493 qq_40160493 3年前

    子查询大多数是作为一个结果给主查询使用,所以子查询不需要排序

    点赞 评论 复制链接分享

相关推荐