Crear, modificar y eliminar desencadenadores
En SMO, los desencadenadores se representan utilizando el objeto Trigger. El código Transact-SQL que se ejecuta cuando se activa el desencadenador está definido por la propiedad TextBody del objeto Trigger. El tipo de desencadenador se establece utilizando otras propiedades del objeto Trigger, como la propiedad Update. Se trat de una propiedad booleana que especifica si el desencadenador se activa por una UPDATE de los registros en la tabla primaria.
El objeto Trigger representa los desencadenadores tradicionales del lenguaje de manipulación de datos (DML). En SQL Server 2008, también se admiten los desencadenadores del lenguaje de definición de datos (DDL). El objeto DatabaseDdlTrigger y el objeto ServerDdlTrigger representan los desencadenadores DDL.
Ejemplo
Para utilizar cualquier ejemplo de código que se proporcione, deberá elegir el entorno de programación, la plantilla de programación y el lenguaje de programación en los que crear su aplicación. Para obtener más información, vea "Cómo crear un proyecto de Visual Basic SMO en Visual Studio .NET" o "Cómo crear un proyecto de Visual C# SMO en Visual Studio .NET" en los Libros en pantalla de SQL Server.
Crear, modificar y quitar un desencadenador en Visual Basic
En este ejemplo de código se muestra cómo crear e insertar un desencadenador de actualización en una tabla existente, denominada Sales, en la base de datos AdventureWorks. El desencadenador envía un mensaje de aviso cuando la tabla se actualiza o cuando se inserta un nuevo registro.
'Connect to the local, default instance of SQL Server.
Dim mysrv As Server
mysrv = New Server
'Reference the AdventureWorks database.
Dim mydb As Database
mydb = mysrv.Databases("AdventureWorks")
'Declare a Table object variable and reference the Customer table.
Dim mytab As Table
mytab = mydb.Tables("Customer", "Sales")
'Define a Trigger object variable by supplying the parent table, schema ,and name in the constructor.
Dim tr As Trigger
tr = New Trigger(mytab, "Sales")
'Set TextMode property to False, then set other properties to define the trigger.
tr.TextMode = False
tr.Insert = True
tr.Update = True
tr.InsertOrder = Agent.ActivationOrder.First
Dim stmt As String
stmt = " RAISERROR('Notify Customer Relations',16,10) "
tr.TextBody = stmt
tr.ImplementationType = ImplementationType.TransactSql
'Create the trigger on the instance of SQL Server.
tr.Create()
'Remove the trigger.
tr.Drop()
Crear, modificar y quitar un desencadenador en Visual C#
En este ejemplo de código se muestra cómo crear e insertar un desencadenador de actualización en una tabla existente, denominada Sales, en la base de datos AdventureWorks. El desencadenador envía un mensaje de aviso cuando la tabla se ha actualizado o se inserta un nuevo registro.
{
//Connect to the local, default instance of SQL Server.
Server mysrv;
mysrv = new Server();
//Reference the AdventureWorks database.
Database mydb;
mydb = mysrv.Databases("AdventureWorks");
//Declare a Table object variable and reference the Customer table.
Table mytab;
mytab = mydb.Tables("Customer", "Sales");
//Define a Trigger object variable by supplying the parent table, schema ,and name in the constructor.
Trigger tr;
tr = new Trigger(mytab, "Sales");
//Set TextMode property to False, then set other properties to define the trigger.
tr.TextMode = false;
tr.Insert = true;
tr.Update = true;
tr.InsertOrder = Agent.ActivationOrder.First;
string stmt;
stmt = " RAISERROR('Notify Customer Relations',16,10) ";
tr.TextBody = stmt;
tr.ImplementationType = ImplementationType.TransactSql;
//Create the trigger on the instance of SQL Server.
tr.Create();
//Remove the trigger.
tr.Drop();
}