Introducing database (DDL) triggers in SQL Server 2005
Much like regular DML triggers, DDL triggers fire in response to an event
happening on the server. However, DDL triggers do not fire in response
to UPDATE, INSERT, or DELETE statements on a table or view. Instead,
they fire in response to Data Definition Language (DDL) statements
that start with the keywords CREATE, ALTER, and DROP.
You can use DDL triggers to audit and regulate database operations.
For instance, you can write a DDL trigger to prevent certain changes
to your database schema, or maybe allow the change but record it
in a log table for auditing purposes.
Certain system stored procedures that perform DDL-like operations
can also fire DDL triggers. The CREATE TYPE statement and the sp_addtype
stored procedure can both fire a DDL trigger. However, not all system
stored procedures fire DDL triggers. The sp_rename stored procedure
for instance does not fire any DDL triggers. You need to test your
DDL triggers to determine their responses to system stored procedures.
DDL triggers can be server-scoped or database-scoped. A database-scoped
DDL trigger is simply called a database trigger. The following example
shows how a database trigger can be used to prevent any table in
the current database from being modified or dropped. Keep in mind
that DDL triggers fire only after the DDL statements that trigger
them are run:
CREATE TRIGGER trigger1
ON DATABASE
FOR DROP_TABLE, ALTER_TABLE AS
PRINT 'You cannot drop or alter this table.'
ROLLBACK
You can temporarily disable a DDL trigger. Disabling a DDL trigger
does not drop it. The trigger will still exists as an object; however,
it will not be triggered by any of statements on which it was programmed.
DDL triggers that are disabled can be re-enabled. Enabling a DDL
trigger causes it to fire in the same way the trigger did when it
was originally created.
DDL triggers do not fire in response to events that affect local
or global temporary tables and stored procedures.
Some DDL statements, like CREATE DATABASE, cannot be used in
DDL triggers. These statements are usually asynchronous, non-transacted
statements.
|