账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    mysql如何把每个用户的记录保留最新10条
    68
    0

    需求是把一个用户登录记录的表(例如叫signin_record)中每个用户的记录保留最新10条,
    以下sql语句只能删除一个用户,请问如何改进?

    `DELETE tb FROM signin_record AS tb ,(SELECT id FROM signin_record ORDER BY id desc LIMIT 1,9) AS tmp,(SELECT DISTINCT user FROM signin_record ORDER BY user desc) AS users
    WHERE tb.id<tmp.id and tb.user=users.user;`

    1
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • 一个人也不错 普通会员 1楼

      在MySQL中,你可以使用ROW_NUMBER()函数和LIMIT关键字来实现这个需求。以下是一个基本的示例:

      sql SELECT user_id, MAX(date) as max_date FROM your_table GROUP BY user_id ORDER BY max_date DESC LIMIT 10;

      在这个示例中,我们首先对每个用户ID按日期进行分组,然后在每个组中找到最大日期并将其设置为新的max_date。然后,我们按照这个新的max_date降序排序结果,最后只返回前10条结果。

      请注意,你需要将your_tableuser_id替换为你的实际表名和用户ID。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部