利用 waitfor 实现毫秒级延迟

 

延迟1毫秒

SELECT getdate()
WAITFOR DELAY   '00:00:00.001'
SELECT getdate()

两次的执行结果分别如下

2008-01-10 22:54:13.513

2008-01-10 22:54:13.513

两次获得的时间完全一样。

延迟两毫秒就能看返回的时间差别

SELECT getdate()
WAITFOR DELAY   '00:00:00.002'
SELECT getdate()

延迟两次的执行结果

2008-01-10 22:58:37.450
2008-01-10 22:58:37.467

由于我用的一个存储过程中需要毫秒级的时间串产生序列号,因为没有延迟,所以会出现序列号相同的问题,所以这个延迟函数就帮了大忙。

SELECT convert(varchar(8),   getdate(),112)  +  replace(convert(varchar(12),getdate(),114),':','') as  NewSerial
WAITFOR DELAY   '00:00:00.002'
SELECT convert(varchar(8),   getdate(),112)  +  replace(convert(varchar(12),getdate(),114),':','') as  NewSerial

执行结果如下

20080110230256640
20080110230256653

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值