SQL Server 中的查询通知

查询通知建立在 Service Broker 基础结构之上,并允许在数据发生更改时向应用程序发送通知。 对提供数据库信息的缓存且需要在源数据发生更改时收到通知的应用程序(如 Web 应用程序)而言,以上功能特别有用。

使用 ADO.NET,可以通过三种方式实现查询通知:

  1. 公开服务器端功能的 SqlNotificationRequest 类提供低级别实现,使你能够利用通知请求执行命令。

  2. 高级别实现由 SqlDependency 类提供,该类可提供源应用程序与 SQL Server 之间的通知功能的高级抽象,使你能够使用依赖项来检测服务器中的更改。 大多数情况下,这是托管客户端应用程序通过适用于 SQL Server 的 .NET Framework 数据提供程序利用 SQL Server 通知功能的最简单、最有效的方法。

  3. 此外,使用 ASP.NET 2.0 或更高版本构建的 Web 应用程序可以使用 SqlCacheDependency 帮助程序类。

如果应用程序需要通过刷新显示或缓存来响应基础数据中的更改,则查询通知非常有用。 如果执行相同命令生成的结果集与最初检索到的结果集不同,则 Microsoft SQL Server 可允许 .NET Framework 应用程序向 SQL Server 发送命令和请求通知。 服务器上生成的通知是通过这些队列发送的,以便在稍后进行处理。

可以为 SELECT 和 EXECUTE 语句设置通知。 使用 EXECUTE 语句时,SQL Server 将为执行的命令(而不是 EXECUTE 语句本身)注册一个通知。 命令必须满足 SELECT 语句的要求和限制。 当注册通知的命令包含多条语句时,数据库引擎将为批处理中的每条语句创建一个通知。

如果您正在开发需要在数据发生更改时提供可靠的次秒级通知的应用程序,请查看通知计划一文中的规划高效的查询通知策略查询通知的替代方法章节。 有关查询通知和 SQL Server Service Broker 的更多信息,请参见以下指向“SQL Server 文档”中文章的链接。

SQL Server 文档

本节内容

启用查询通知
介绍如何使用查询通知,其中包括启用和使用查询通知的要求。

ASP.NET 应用程序中的 SqlDependency
演示如何使用 ASP.NET 应用程序中的查询通知。

使用 SqlDependency 检测更改
演示如何检测查询结果与最初接收的结果不同的情况。

使用 SqlNotificationRequest 的 SqlCommand 执行
演示如何将 SqlCommand 对象配置为使用查询通知。

参考

SqlNotificationRequest
介绍 SqlNotificationRequest 类及其所有成员。

SqlDependency
介绍 SqlDependency 类及其所有成员。

SqlCacheDependency
介绍 SqlCacheDependency 类及其所有成员。

请参阅