小菜来袭 2017-12-11 09:23 采纳率: 40%
浏览 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 模电中二极管,三极管和电容的应用
  • ¥15 关于模型导入UNITY的.FBX: Check external application preferences.警告。
  • ¥15 气象网格数据与卫星轨道数据如何匹配
  • ¥100 java ee ssm项目 悬赏,感兴趣直接联系我
  • ¥15 微软账户问题不小心注销了好像
  • ¥15 x264库中预测模式字IPM、运动向量差MVD、量化后的DCT系数的位置
  • ¥15 curl 命令调用正常,程序调用报 java.net.ConnectException: connection refused
  • ¥20 关于web前端如何播放二次加密m3u8视频的问题
  • ¥15 使用百度地图api 位置函数报错?
  • ¥15 metamask如何添加TRON自定义网络