sql server如何每10秒执行一条SQL语句

sql server如何每10秒执行一条SQL语句,第1张

可以用

waitfor delay '000:00:10'

把这个放在要执行的语句之前,这样过10秒钟才会执行语句,结合循环操作就可以每10秒执行一次了。

这个最好和语句同时放在存储过程中,执行完语句后,再调用存储过程就可以实现循环了。

用作业调度一次就可以了,把exec p_ZQJ_YX710_I_test加在存储过程最后,另外把while循环去掉,只要自己调用自己就可以了。另外最好设置一个配置表,在其中放置一个值用来确定是否要继续循环下去,如果不想让它循环下去,只要将那个配置值改一下。否则在重新启动SQL SERVER服务之前,这个存储过程会无限循环下去,一般是不好终止的。

create proc p_ZQJ_YX710_I_test

as

declare @d datetime

INSERT Runtimedbohistory(TagName, QualityDetail, Value, DateTime)

SELECT rtrim(t1name), 192,t1curval,DATEADD(ss, t1timestamp_high, '1970-01-01 08:00:00000') AS Expr1

FROM scadasqltestgzwebdboanalog t1 where t1name ='ZQJ_YX710_I'

waitfor delay '00:00:10'--定义等待10秒

exec p_ZQJ_YX710_I_test

  DELAY参数是指需要等待延迟的时间

  WAITFOR

  在达到指定时间或时间间隔之前,或者指定语句至少修改或返回一行之前,阻止执行批处理、存储过程或事务。

  DELAY

  可以继续执行批处理、存储过程或事务之前必须经过的指定时段,最长可为 24 小时。

要不影响其他代码的运行,就是说在延时的时候也要能够处理窗体消息。

否则程序就会没有响应。

如果你一定要按照这个代码结构,我提供一个思路:

1、使用内核可等待的计时器对象来实现延时。

CreateWaitableTimer创建

SetWaitableTimer设定延时时间

2、等待计时器延时不可使用WaitForSingleObject,使用MsgWaitForMultipleObjects等待,类型用QS_ALLEVENTS,一定要检查等待的返回值

3、对于返回值的处理,如果是WAIT_OBJECT_0,那么说明延时时间到了,继续运行后面的语句

如果返回WAIT_OBJECT_0 + 1,则说明有消息来了,不断调用PeekMessage,参数PM_NOREMOVE,如果返回非0,则调用AfxGetThread()->PumpMessage(),然后检查这个的返回值,返回0则调用AfxPostQuitMessage并结束循环退出函数,如果返回非0则继续下一轮调用PeekMessage

4、完成以后可以考虑关闭可等待的计时器内核对象

简单说就是,把原来只调用一个Sleep改为用一个定时器设置一个目标时间,然后等那个目标时间到来。在等的过程中同时还检查有没有消息来,有的话处理消息,这样窗口上的按钮啊啥的也都还能点(当然你别再点会有类似处理过程的按钮……),也不会提示没有响应,窗口要拖动也还能拖动。方法比较麻烦,但是确确实实不需要创建新线程,完全依靠内核的线程调度机制。

如果不一定要用这样的代码结构,那么把这些语句放入一个新的线程里面运行就好了。

欢迎分享,转载请注明来源:浪漫分享网

原文地址:https://hunlipic.com/langman/3622468.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-08-16
下一篇2023-08-16

发表评论

登录后才能评论

评论列表(0条)

    保存