吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1165|回复: 6
收起左侧

[求助] 请教 sql server 问题,感谢!

[复制链接]
谢天谢地谢广坤 发表于 2021-9-16 09:52
25吾爱币
本帖最后由 谢天谢地谢广坤 于 2021-9-17 09:37 编辑

如图,需要计算出同一个单号下,审批人id‘a’每次的停留时间(a的审批时间-上一个人的审批时间)


最终结果只显示'a'的停留时间、单号、审批人id


表结构:

Snipaste_2021-09-16_09-45-13.png

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

xiaoyu2032 发表于 2021-9-16 12:06
你这个表设计的不合理,如果是要判断时间的话,不应该将时间转成字符串存在数据表中,应该以时间类型存储。转成字符串后,直接用字符串进行比较的话由于字符串格式的问题会出现排序错误。用时间类型存储的话就是数值的比较,排序简单,相减就是时间差,不需要再次进行转换计算。
 楼主| 谢天谢地谢广坤 发表于 2021-9-17 09:35
xiaoyu2032 发表于 2021-9-16 12:06
你这个表设计的不合理,如果是要判断时间的话,不应该将时间转成字符串存在数据表中,应该以时间类型存储。 ...

数据库里是时间类型,只是用excel举个例子
dlxg 发表于 2021-9-23 08:27
没太看明白,不知道我理解的对不对。
假设有一条单号,456,目前有3个人审批,审批如下:
  • a---456---2021年9月23日08:23:00
  • b---456---2021年9月23日08:23:09
  • c---456---2021年9月23日08:23:17


那么,现在查询单号456的审批时间,结果按降序排列,得到最后一次审批时间,2021年9月23日08:23:17,把此结果赋值给临时变量temp。
现在第4个人审批,d---456---2021年9月23日08:26:25,拿审批时间2021年9月23日08:26:25减去临时变量temp,是不是就是你要的结果?
 楼主| 谢天谢地谢广坤 发表于 2021-9-23 09:29
dlxg 发表于 2021-9-23 08:27
没太看明白,不知道我理解的对不对。
假设有一条单号,456,目前有3个人审批,审批如下:

没错,是这个意思。

现在遇到的问题是,同一个单号d可能会审批多次,需要知道d每次停留了多久,然后结果只要审批人d,单号,停留时间这三个字段。

请问可以实现么?
dlxg 发表于 2021-9-23 11:38
谢天谢地谢广坤 发表于 2021-9-23 09:29
没错,是这个意思。

现在遇到的问题是,同一个单号d可能会审批多次,需要知道d每次停留了多久,然后结 ...

如果是新审批的话,就按照流程,本次审批的时候,计算跟上次审批的时间差,就等于停留时间了。

如果是要完善以前的,那可能要在数据库中间计算,手动补录了。
 楼主| 谢天谢地谢广坤 发表于 2021-9-23 13:47
dlxg 发表于 2021-9-23 11:38
如果是新审批的话,就按照流程,本次审批的时候,计算跟上次审批的时间差,就等于停留时间了。

如果是 ...

是的,但是这段sql我不会写。。。
我需要最后结果只显示d的停留时间,但是条件where=‘d’之后,时间差就在所有d的审批时间里计算了,但实际上是要和上一个人计算嘛。
请问这里该怎么解决?感谢!!
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 22:35

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表