Gestire gli eventi SMO

Si applica a: SQL Server database SQL di Azure Istanza gestita di SQL di Azure Azure Synapse Analytics

Vi sono tipi di eventi del server che possono essere sottoscritti tramite un gestore di eventi e l'oggetto ServerConnection.

Molte delle classi di istanza in SQL Server Management Objects (SMO) possono attivare eventi quando si verificano determinate azioni nel server.

Questi eventi possono essere gestiti a livello di codice configurando un gestore evento e sottoscrivendo gli eventi associati. Questo tipo di gestione degli eventi è temporanea perché quando viene chiuso il programma client SMO vengono rimosse tutte le sottoscrizioni.

Gestione degli eventi ConnectionContext

L'oggetto ServerConnection supporta diversi tipi di evento. La proprietà dell'evento deve essere impostata su un'istanza di un gestore evento appropriato e l'oggetto gestore evento deve essere definito come una funzione protetta che gestisce l'evento.

Sottoscrizione evento

Per gestire gli eventi è necessario scrivere una classe del gestore evento, crearne un'istanza, assegnare il gestore evento all'oggetto padre e infine effettuare la sottoscrizione all'evento.

Per gestire gli eventi, è necessario scrivere una classe del gestore evento. La classe del gestore evento può contenere più di una funzione del gestore evento e deve essere installata per poter gestire gli eventi. Le funzioni del gestore eventi ricevono informazioni sull'evento dal parametro ServerEventNotificatificationArgs che può essere usato per segnalare informazioni sull'evento.

I tipi di eventi di database e server che è possibile gestire sono elencati nella DatabaseEventSet classe e nella ServerEventSetclasse .

Esempi

Per usare qualsiasi esempio di codice fornito, è necessario scegliere l'ambiente di programmazione, il modello di programmazione e il linguaggio di programmazione in cui creare l'applicazione. Per altre informazioni, vedere How to Create a Visual C# SMO Project in Visual Studio .NET(Come creare un progetto SMO di Visual C# in Visual Studio .NET).

Registrare i gestori eventi e sottoscrivere la gestione degli eventi in .NET

Gli esempi di codice seguenti illustrano come configurare il gestore eventi e come sottoscrivere gli eventi del database in .NET.

Visual Basic

In questo esempio di codice viene illustrato come configurare il gestore dell'evento e come effettuare la sottoscrizione degli eventi del database.

'Create an event handler subroutine that runs when a table is created.
Private Sub MyCreateEventHandler(ByVal sender As Object, ByVal e As ServerEventArgs)
    Console.WriteLine("A table has just been added to the AdventureWorks2022 database.")
End Sub

'Create an event handler subroutine that runs when a table is deleted.
Private Sub MyDropEventHandler(ByVal sender As Object, ByVal e As ServerEventArgs)
    Console.WriteLine("A table has just been dropped from the AdventureWorks2022 database.")
End Sub

Sub Main()
    'Connect to the local, default instance of SQL Server.

    Dim srv As Server
    srv = New Server

    'Reference the AdventureWorks2022 database.
    Dim db As Database
    db = srv.Databases("AdventureWorks2022")

    'Create a database event set that contains the CreateTable event only.
    Dim databaseCreateEventSet As New DatabaseEventSet
    databaseCreateEventSet.CreateTable = True

    'Create a server event handler and set it to the first event handler subroutine.
    Dim serverCreateEventHandler As ServerEventHandler
    serverCreateEventHandler = New ServerEventHandler(AddressOf MyCreateEventHandler)

    'Subscribe to the first server event handler when a CreateTable event occurs.
    db.Events.SubscribeToEvents(databaseCreateEventSet, serverCreateEventHandler)

    'Create a database event set that contains the DropTable event only.
    Dim databaseDropEventSet As New DatabaseEventSet
    databaseDropEventSet.DropTable = True

    'Create a server event handler and set it to the second event handler subroutine.
    Dim serverDropEventHandler As ServerEventHandler
    serverDropEventHandler = New ServerEventHandler(AddressOf MyDropEventHandler)

    'Subscribe to the second server event handler when a DropTable event occurs.
    db.Events.SubscribeToEvents(databaseDropEventSet, serverDropEventHandler)

    'Start event handling.
    db.Events.StartEvents()

    'Create a table on the database.
    Dim tb As Table
    tb = New Table(db, "Test_Table")

    Dim mycol1 As Column
    mycol1 = New Column(tb, "Name", DataType.NChar(50))
    mycol1.Collation = "Latin1_General_CI_AS"
    mycol1.Nullable = True

    tb.Columns.Add(mycol1)
    tb.Create()

    'Remove the table.
    tb.Drop()

    'Wait until the events have occurred.
    Dim x As Integer
    Dim y As Integer
    For x = 1 To 1000000000
        y = x*2
    Next

    'Stop event handling.
    db.Events.StopEvents()
End Sub