穿梭机丶 2023-04-21 18:45 采纳率: 75%
浏览 30
已结题

sql sever 按一周(7天)分组统计次数与金额

t表
字段有:姓名,身份证号,开单时间,金额,其中开单时间是datetime类型,其余是varchar

情况:一人一年内有多次开单记录
目标:查找一周内超过2次的开单记录,例如:张三有3条记录,4月1日10时、4月8日13时、4月12日7时,输出张三,4月8日和4月12日的记录,而忽略4月1日的记录。

中间过程有按一周分组吧??

看过论坛内很多代码,有按小时统计,按天统计,需要现在日期不确定,所以长了很久,真不会。谢谢各位了。

  • 写回答

3条回答 默认 最新

  • 三千烦恼丝xzh 2023-04-21 19:05
    关注

    取每行时间lead、lag窗口over(partition by user)然后计算日期差是否在七天之内就好。

    select * from (
    select *, lead(开单时间) over(partition by 用户) lead_time, lag(开单时间) over(partition by 用户) lag_time from t ) tmp where lag_time - 开单时间 < 7 or 开单时间 - lead_time < 7
    

    时间计算自己改一下

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 4月29日
  • 已采纳回答 4月21日
  • 创建了问题 4月21日

悬赏问题

  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥15 DruidDataSource一直closing
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据
  • ¥15 (关键词-阻抗匹配,HFSS,RFID标签)
  • ¥50 sft下载大文阻塞卡死