weixin_41913939 2022-02-11 18:08 采纳率: 70%
浏览 60
已结题

sql server 计算同一列两行的时间差

sql server 计算同一列两行的时间差:

数据库信息如下:
ID name DateTime
1 14774 2022-02-08 19:35:26.137
2 16284 2022-02-09 08:14:35.220
3 16284 2022-02-09 08:14:33.883
4 14774 2022-02-09 08:14:33.547
5 16284 2022-02-09 08:14:33.543
6 14774 2022-02-09 08:14:32.080
7 16284 2022-02-09 08:14:32.077
8 16284 2022-02-09 08:14:32.073
9 16284 2022-02-09 08:14:32.067

需求如下:

  1. 按照“name”列进行分组
  2. 计算上一行和下一行的时间差
  • 写回答

2条回答 默认 最新

  • chuifengde 2022-02-11 21:17
    关注

    是这个意思吗?

    declare @a table(ID int, name varchar(20), DateTime datetime)
    insert @a 
    select 1, '14774', '2022-02-08 19:35:26.137'
    union all select 2 ,'16284', '2022-02-09 08:14:35.220'
    union all select 3 ,'16284', '2022-02-09 08:14:33.883'
    union all select 4 ,'14774', '2022-02-09 08:14:33.547'
    union all select 5 ,'16284', '2022-02-09 08:14:33.543'
    union all select 6 ,'14774', '2022-02-09 08:14:32.080'
    union all select 7 ,'16284', '2022-02-09 08:14:32.077'
    union all select 8 ,'16284', '2022-02-09 08:14:32.073'
    union all select 9 ,'16284', '2022-02-09 08:14:32.067'
    
    select id,
        name,
        datetime,d=DATEDIFF(ms,datetime,(select top 1 datetime from @a where id>a.id and name=a.name order by id))
    from @a a 
    order by name,id
    
    --result
    1    14774    2022-02-08 19:35:26.137    45547410
    4    14774    2022-02-09 08:14:33.547    -1466
    6    14774    2022-02-09 08:14:32.080    NULL
    2    16284    2022-02-09 08:14:35.220    -1336
    3    16284    2022-02-09 08:14:33.883    -340
    5    16284    2022-02-09 08:14:33.543    -1466
    7    16284    2022-02-09 08:14:32.077    -3
    8    16284    2022-02-09 08:14:32.073    -6
    9    16284    2022-02-09 08:14:32.067    NULL
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月20日
  • 已采纳回答 2月12日
  • 创建了问题 2月11日

悬赏问题

  • ¥30 Matlab打开默认名称带有/的光谱数据
  • ¥50 easyExcel模板 动态单元格合并列
  • ¥15 res.rows如何取值使用
  • ¥15 在odoo17开发环境中,怎么实现库存管理系统,或独立模块设计与AGV小车对接?开发方面应如何设计和开发?请详细解释MES或WMS在与AGV小车对接时需完成的设计和开发
  • ¥15 CSP算法实现EEG特征提取,哪一步错了?
  • ¥15 游戏盾如何溯源服务器真实ip?需要30个字。后面的字是凑数的
  • ¥15 vue3前端取消收藏的不会引用collectId
  • ¥15 delphi7 HMAC_SHA256方式加密
  • ¥15 关于#qt#的问题:我想实现qcustomplot完成坐标轴
  • ¥15 下列c语言代码为何输出了多余的空格