Special Considerations When Using Query Notifications
Special Considerations When Using Query Notifications
Applications that use query notification features need to take into account the following special considerations.
Valid Queries
Query notifications only support certain Transact-SQL statements.
First, to support notifications, queries must not contain:
- Derived tables.
- Rowset functions.
- The UNION operator.
- Subqueries.
- Outer or self-joins.
- The TOP clause.
- The DISTINCT keyword.
- A COUNT(*) aggregate.
- AVG, MAX, MIN, STDEV, STDEVP, VAR, or VARP aggregates.
- User-defined aggregates.
- A SUM function that references a nullable expression.
- The full-text predicates CONTAINS or FREETEXT.
- A COMPUTE or COMPUTE BY clause.
- Aggregate expressions if GROUP BY is not specified in a select list. If GROUP BY is specified, the select list must contain a COUNT_BIG(*) expression, and cannot specify HAVING, CUBE, or ROLLUP.
- An INTO clause.
- Conditions that will preclude results from changing (e.g. WHERE 1=0).
- FOR BROWSE (or be running with SET NO_BROWSETABLE ON).
- A READPAST locking hint.
- Second, queries must not reference:
- Temporal tables or table variables.
- Tables or views from other databases or servers.
- Any other views or table-valued functions.
- Any system tables or views.
- Any nondeterministic function, including ranking and windowing functions.
- Any server global variables.
- Any Service Broker queue.
- Synonyms.
Finally, queries must reference a base table or view.
Rapid Updates
An application that uses Query Notifications must take into consideration cases where a notification occurs immediately. When data is changed on the server, a notification message will be sent to the appropriate Service Broker queue. Applications need to reregister to receive additional notifications. Therefore, if a data set is updated quickly by multiple applications, an application could receive a notification, retrieve the data, and then get another update notification almost immediately after the cache has been refreshed. Applications that use Query Notifications must be written to take this case into account. If an application uses data that is constantly updated, another strategy for caching data may be more appropriate.
Transactions
If multiple modifications are made to a set of data with a registered notification request, and those changes occur within a transaction, only a single notification event will be sent.
Service Account for SQL Server
An application will not receive notifications from an instance of SQL Server that uses the Local System account as the service account.
(Attach/Detach,Backup/Restore),Possibly can make this mistake:"An exception occurred while enqueueing a message in the target queue. Error: 15517, State: 1. Cannot execute as the database principal because the principal "dbo" does not exist, this type of principal cannot be impersonated, or you do not have permission.",So Query Notification Couldn't work,try this:ALTER AUTHORIZATION ON DATABASE::[Your DB Name] TO [sa].