SqlTriggerContext Klasse

Definition

Stellt Kontextinformationen über den ausgelösten Trigger bereit.Provides contextual information about the trigger that was fired.

public ref class SqlTriggerContext sealed
public sealed class SqlTriggerContext
type SqlTriggerContext = class
Public NotInheritable Class SqlTriggerContext
Vererbung
SqlTriggerContext

Beispiele

Das folgende Beispiel zeigt, SqlTriggerContext wie ein-Objekt verwendet wird, Insert um zu bestimmen, ob eine Aktion aufgetreten ist.The following example shows a SqlTriggerContext object being used to determine if an Insert action occurred. Wenn eine Zeile in die userTabelle eingefügt wurde, werden der Benutzername und der echte Name aus der eingefügten Zeile abgerufen und dann der UserNameAudit -Tabelle hinzugefügt.If a row was inserted into the user's table, the user name and real name are retrieved from the inserted row and then added to the UserNameAudit table.

[SqlTrigger(Name = @"UsersAudit", Target = "[dbo].[users]", Event = "FOR INSERT")]
public static void UsersAudit()
{
   // Get the trigger context.
   string userName;
   string realName;
   SqlCommand command;
   SqlTriggerContext triggContext = SqlContext.TriggerContext;
   SqlDataReader reader;
   
   switch (triggContext.TriggerAction)
   {
      case TriggerAction.Insert:

      // Retrieve the connection that the trigger is using.
      using (SqlConnection connection
         = new SqlConnection(@"context connection=true"))
      {
         connection.Open();
 
         // Get the inserted row.
         command = new SqlCommand(@"SELECT * FROM INSERTED;",
                                  connection);

         // Get the user name and real name of the inserted user.
         reader = command.ExecuteReader();
         reader.Read();
         userName = (string)reader[0];
         realName = (string)reader[1];
         reader.Close();

         // Insert the user name and real name into the auditing table.
         command = new SqlCommand(@"INSERT [dbo].[UserNameAudit] (userName, realName) " 
                  + @"VALUES (@userName, @realName);", connection);

         command.Parameters.Add(new SqlParameter("@userName", userName));
         command.Parameters.Add(new SqlParameter("@realName", realName));
               
         command.ExecuteNonQuery();               
            
      }
         
      break;
   }
}
<SqlTrigger(Name:="UsersAudit", Target:="[dbo].[users]", Event:="FOR INSERT")> _
Public Shared Sub UsersAudit()
        
   Dim command As SqlCommand
   Dim triggContext As SqlTriggerContext
   Dim reader As SqlDataReader
   Dim userName As String
   Dim realName As String

         
   ' Get the trigger context.
   triggContext = SqlContext.TriggerContext        

   Select Case triggContext.TriggerAction
           
      Case TriggerAction.Insert

         ' Retrieve the connection that the trigger is using.
         Using connection As New SqlConnection("context connection=true")
            connection.Open()

            ' Get the inserted row.
            command = new SqlCommand("SELECT * FROM INSERTED;", connection)
            
            ' Get the user name and real name of the inserted user.                
            reader = command.ExecuteReader()
            reader.Read()
            userName = CType(reader(0), String)
            realName = CType(reader(1), String)

            reader.Close()

            ' Insert the user name and real name into the auditing table.
            command = New SqlCommand("INSERT [dbo].[UserNameAudit] (userName, realName) " & _
               "VALUES (@userName, @realName);", connection)

            command.Parameters.Add(new SqlParameter("@userName", userName))
            command.Parameters.Add(new SqlParameter("@realName", realName))
                 
            command.ExecuteNonQuery()
                 
          End Using
         
   End Select

End Sub

Hinweise

Die bereitgestellten Kontextinformationen umfassen den Typ der Aktion, die den Trigger ausgelöst hat, die Spalten, die bei einem Aktualisierungs Vorgang geändert wurden, und im Fall eines DDL-Auslösers (Data Definition Language) eine XML-EVENTDATA-Struktur (siehe Transact-SQL). Reference), die den auslösenden Vorgang beschreibt.The contextual information provided includes the type of action that caused the trigger to fire, which columns were modified in an UPDATE operation, and, in the case of a data definition language (DDL) trigger, an XML EventData structure (see Transact-SQL Reference) that describes the triggering operation.

Eine Instanz von SqlTriggerContext ist in der SqlContext -Klasse verfügbar, wenn der Code innerhalb eines-Auslösers TriggerContext durch die-Eigenschaft ausgeführt wird.An instance of SqlTriggerContext is available from the SqlContext class, when the code is running inside a trigger through the TriggerContext property.

Eigenschaften

ColumnCount

Ruft die Anzahl der Spalten in der an den Trigger gebundenen Datentabelle ab.Gets the number of columns contained by the data table bound to the trigger. Diese Eigenschaft ist schreibgeschützt.This property is read-only.

EventData

Ruft die Ereignisdaten für eine bestimmte Aktion ab, die den Trigger ausgelöst hat.Gets the event data specific to the action that fired the trigger.

TriggerAction

Gibt an, welche Aktion den Trigger ausgelöst hat.Indicates what action fired the trigger.

Methoden

Equals(Object)

Bestimmt, ob das angegebene Objekt mit dem aktuellen Objekt identisch ist.Determines whether the specified object is equal to the current object.

(Geerbt von Object)
GetHashCode()

Fungiert als Standardhashfunktion.Serves as the default hash function.

(Geerbt von Object)
GetType()

Ruft den Type der aktuellen Instanz ab.Gets the Type of the current instance.

(Geerbt von Object)
IsUpdatedColumn(Int32)

Gibt true zurück, wenn eine Spalte bei einer INSERT-Anweisung oder einer UPDATE-Anweisung geändert wurde.Returns true if a column was affected by an INSERT or UPDATE statement.

MemberwiseClone()

Erstellt eine flache Kopie des aktuellen Object.Creates a shallow copy of the current Object.

(Geerbt von Object)
ToString()

Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt.Returns a string that represents the current object.

(Geerbt von Object)

Gilt für: