可以用
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改为用一个定时器设置一个目标时间,然后等那个目标时间到来。在等的过程中同时还检查有没有消息来,有的话处理消息,这样窗口上的按钮啊啥的也都还能点(当然你别再点会有类似处理过程的按钮……),也不会提示没有响应,窗口要拖动也还能拖动。方法比较麻烦,但是确确实实不需要创建新线程,完全依靠内核的线程调度机制。
如果不一定要用这样的代码结构,那么把这些语句放入一个新的线程里面运行就好了。
欢迎分享,转载请注明来源:浪漫分享网
评论列表(0条)