项目中要用到一个SQL2005的CLR扩展SP,里面要向一个HTTP接口发送数据,是从一个表里抓取数据然后循环向HTTP接口发送数据,为了防止HTTP接口负荷过高,必须延时一下。在SQL2005中可以用waitfor语句实现。

在MSDN上的说明:

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

语法


WAITFOR
{DELAY 'time_to_pass' | TIME 'time_to_execute' | [ ( receive_statement ) | ( get_conversation_group_statement ) ] [ , TIMEOUT timeout ]
}

参数:

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

' time_to_pass '
等待的时段。可以使用 datetime 数据可接受的格式之一指定 time_to_pass,也可以将其指定为局部变量。不能指定日期;因此,不允许指定 datetime 值的日期部分。

TIME
指定的运行批处理、存储过程或事务的时间。

' time_to_execute '
WAITFOR 语句完成的时间。可以使用 datetime 数据可接受的格式之一指定 time_to_execute,也可以将其指定为局部变量。不能指定日期;因此,不允许指定 datetime 值的日期部分。

receive_statement
有效的 RECEIVE 语句。

备注:

执行 WAITFOR 语句时,事务正在运行,并且其他请求不能在同一事务下运行。

实际的时间延迟可能与 time_to_pass、time_to_execute 或 timeout 中指定的时间不同,它依赖于服务器的活动级别。时间计数器在计划完与 WAITFOR 语句关联的线程后启动。如果服务器忙碌,则可能不会立即计划线程;因此,时间延迟可能比指定的时间要长。

WAITFOR 不更改查询的语义。如果查询不能返回任何行,WAITFOR 将一直等待,或等到满足 TIMEOUT 条件(如果已指定)。

不能对 WAITFOR 语句打开游标。

不能对 WAITFOR 语句定义视图。

如果查询超出了 query wait 选项的值,则 WAITFOR 语句参数不运行即可完成。有关该配置选项的详细信息,请参阅 query wait 选项。若要查看活动进程和正在等待的进程,请使用 sp_who。

每个 WAITFOR 语句都有与其关联的线程。如果对同一服务器指定了多个 WAITFOR 语句,可将等待这些语句运行的多个线程关联起来。SQL Server 将监视与 WAITFOR 语句关联的线程数,并在服务器开始遇到线程不足的问题时,随机选择其中部分线程以退出。

在保留禁止更改 WAITFOR 语句所试图访问的行集的锁的事务中,可通过运行包含 WAITFOR 语句的查询来创建死锁。如果可能存在上述死锁,则 SQL Server 会标识相应情况并返回空结果集。

-- 以下示例在晚上 10:20 (22:20) 执行存储过程 sp_update_job。
USE msdb;
EXECUTE sp_add_job @job_name = 'TestJob';
BEGINWAITFOR TIME '22:20';EXECUTE sp_update_job @job_name = 'TestJob',@new_name = 'UpdatedJob';
END;
GO
-- 以下示例在两小时的延迟后执行存储过程。BEGINWAITFOR DELAY '02:00';EXECUTE sp_helpdb;
END;
GO
 
 
--对 WAITFOR DELAY 使用局部变量
--以下示例显示如何对 WAITFOR DELAY 选项使用局部变量。将创建一个存储过程,该过程将等待可变的时间段,然后将经过的小时、分钟和秒数信息返回给用户。USE AdventureWorks;
GO
IF OBJECT_ID('dbo.TimeDelay_hh_mm_ss','P') IS NOT NULLDROP PROCEDURE dbo.TimeDelay_hh_mm_ss;
GO
CREATE PROCEDURE dbo.TimeDelay_hh_mm_ss (@DelayLength char(8)= '00:00:00')
AS
DECLARE @ReturnInfo varchar(255)
IF ISDATE('2000-01-01 ' + @DelayLength + '.000') = 0BEGINSELECT @ReturnInfo = 'Invalid time ' + @DelayLength + ',hh:mm:ss, submitted.';-- This PRINT statement is for testing, not use in production.PRINT @ReturnInfo RETURN(1)END
BEGINWAITFOR DELAY @DelayLengthSELECT @ReturnInfo = 'A total time of ' + @DelayLength + ', hh:mm:ss, has elapsed! Your time is up.'-- This PRINT statement is for testing, not use in production.PRINT @ReturnInfo;
END;
GO
/* This statement executes the dbo.TimeDelay_hh_mm_ss procedure. */
EXEC TimeDelay_hh_mm_ss '00:00:10';
GO

转载于:https://www.cnblogs.com/aji88/archive/2009/11/10/1599591.html

waitfor 语句相关推荐

  1. SQL 流程控制语句 之四 WAITFOR语句介绍

    一.使用 WAITFOR delay [例]等待1小时10分零12秒后执行select语句 WAITFOR delay '01:10:12' Select * from publishers 二.使用 ...

  2. SQL Server-流程控制 6,WaitFor 语句

    ylbtech-SQL Server:SQL Server-流程控制 6,WaitFor 语句 SQL Server 流程控制中的 WaitFor 语句. 1,WaitFor 语句 1 --===== ...

  3. SQL Server 2008之WaitFor

    在SQL Server 2005以上版本中,在一个增强的WaitFor命令,其作用可以和一个job相当.但使用更加简捷. 看MSDN: http://msdn.microsoft.com/zh-cn/ ...

  4. SQL:waitfor的使用

    摘自:http://www.cnblogs.com/downmoon/archive/2010/12/07/1899233.html 在SQL Server 2005以上版本中,在一个增强的WaitF ...

  5. mysql导入多条数据语句_MySQL插入多条记录和REPLACE语句

    今天遇到样一个问题,在使用Mysql数据库时,新建一个表,并设置主键为自增长,结果当我一次执行多条插入语句时悲剧了,它竟然报错了,信息如下: 错误码: 1064 You have an error i ...

  6. sql语句延时执行或者是指定时间执行

    --使用waitfor语句延迟或暂停程序的执行 --waitfor{delay'time'|time 'time'} delay是指间隔时间 最长到24小时 time是指定时间执行 waitfor d ...

  7. SQL Server 2012学习笔记 (三) ----- SQL Server SQL语句

      在很多情况下,可以用CREATE TABLE语句创建数据表.使用ALTER TABLE语句修改表结构.使用DROP TABLE语句删除表:   可以使用CREATE DATABASE创建数据库.A ...

  8. waitFor()一直等待,线程阻塞问题

    waitFor()一直等待,线程阻塞问题 -转载–Java中使用Runtime和Process类运行外部程序 使用Runtime.getRuntime().exec()方法可以在java程序里运行外部 ...

  9. 死锁产生的原因和解锁的方法

    产生死锁的四个必要条件: (1) 互斥条件:一个资源每次只能被一个进程使用. (2) 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放. (3) 不剥夺条件:进程已获得的资源,在末使 ...

最新文章

  1. 半导体并购停不下来 ADI拟148亿美元收购Linear
  2. Python第三章-字符串
  3. 20155222卢梓杰 课堂测试ch06补做
  4. iOS 根据图片URL从本地相册获取图片
  5. Eclipse - CDT使用GDB调试C++的问题-无源文件命名(No source file named)
  6. Android—Gson原理解析
  7. mysql建表的规则_MYSQL建表规则 - Love彼岸花开的个人空间 - OSCHINA - 中文开源技术交流社区...
  8. css特性:空白外边距互相叠加
  9. (转载)mysql查询今天、昨天、7天、近30天、本月、上一月数据
  10. Java Threads -- 数据同步(1)
  11. Smobiler错误记录
  12. 系统异常日志处理的思考
  13. ASO优化方法_获取ASO关键词指数接口
  14. hdu2243之AC自动机+矩阵乘法
  15. PHP编写poc,代码实战/萌新如何编写sql注入的poc
  16. 微信php带菜单事件,phpcms微信插件自定义菜单绑定栏目获取消息的实现与应用
  17. WORD邮件合并打印EXCEL数据制作大量奖证、奖状、准考证、成绩单、明信片、信封等个人报表
  18. 【马红“名师+”研修共同体】“课” 展风采,“研”无止境----教学交流活动(二)
  19. ESP8266人体感应项目
  20. Linux内核的组成

热门文章

  1. raw文件 linux,4款Linux下的RAW格式图片编辑软件
  2. C#ArcEngine二次开发——创建与调用AOI书签
  3. Matlab中disp函数的使用
  4. 艾美捷ICT FLICA天冬氨酸蛋白酶(Caspase)活性检测试剂盒说明书
  5. PMP项目管理认证第一节(备考阶段准备)
  6. (4)Fast R-CNN:简化 SPP 层 + 多任务联合训练 它快起来了~
  7. 用PowerShell批量收回wsp包
  8. 私家影院,书房影院,客厅影院装修设中需要注意什么?
  9. 最简单的三层神经网络Matlab实现
  10. 虚拟机集群搭建网络构建