小菜来袭 2017-12-11 09:23 采纳率: 50%
浏览 1082
已采纳

SQL Server 操作数据库数据的问题

原本从2017-11-28号到今天12-11号 这段时间内User表中每小时有100条数据 现在想删除数据但是每
小时要保留一组 相当于一天24条数据 求sql语句怎么写?
时间字段是dactime

  • 写回答

6条回答 默认 最新

  • 椎名小由奈 2017-12-11 09:44
    关注

    参考一下:

    分组后排序,赋值rownum,然后取rownum=1,就是要保留的一组, 最后删除除此之外的所有数据。

     delete * from MyTable b where b.ID not in
    (
        select  t.ID  from 
        (
            select ID, row_number() over(partition by MyTime order by UserName desc) rownum from MyTable
        ) t  where t.rownum = 1 
    )
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 DIFY API Endpoint 问题。
  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突