可以使用事件处理程序和 ServerConnection 对象订阅服务器事件类型。
SQL Server 管理对象(SMO)中的许多实例类可以在服务器上执行某些作时触发事件。
可以通过设置事件处理程序并订阅关联的事件,以编程方式处理这些事件。 这种类型的事件处理是暂时性的,因为 SMO 客户端程序退出时会删除所有订阅。
ConnectionContext 事件处理
该 ServerConnection 对象支持多种事件类型。 事件属性必须设置为适当的事件处理程序的实例,并且事件处理程序对象必须定义为处理事件的受保护函数。
事件订阅
可以通过编写事件处理程序类、创建它的实例、将事件处理程序分配给父对象,然后订阅事件来处理事件。
必须写入事件处理程序类来处理事件。 事件处理程序类可以包含多个事件处理程序函数,并且必须安装才能处理的事件。 事件处理程序函数从 ServerEventNotificatificationArgs 参数接收有关事件的信息,该参数可用于报告有关事件的信息。
可以处理的数据库和服务器事件的类型在类和ServerEventSet类中DatabaseEventSet列出。
示例:
若要使用提供的任何代码示例,必须选择要在其中创建应用程序的编程环境、编程模板和编程语言。 有关详细信息,请参阅 SQL Server 联机丛书中的“如何:在 Visual Studio .NET 中创建 Visual Basic SMO 项目”或“如何:在 Visual Studio .NET 中创建 Visual C# SMO 项目”。
在 Visual Basic 中注册事件处理程序和订阅事件处理
此代码示例演示如何设置事件处理程序以及如何订阅数据库事件。
在 Visual C 中注册事件处理程序和订阅事件处理#
此代码示例演示如何设置事件处理程序以及如何订阅数据库事件。
//Create an event handler subroutine that runs when a table is created.
private void MyCreateEventHandler(object sender, ServerEventArgs e)
{
Console.WriteLine("A table has just been added to the AdventureWorks2012 database.");
}
//Create an event handler subroutine that runs when a table is deleted.
private void MyDropEventHandler(object sender, ServerEventArgs e)
{
Console.WriteLine("A table has just been dropped from the AdventureWorks2012 database.");
}
public void Main()
{
//Connect to the local, default instance of SQL Server.
Server srv;
srv = new Server();
//Reference the AdventureWorks2012 database.
Database db;
db = srv.Databases("AdventureWorks2012");
//Create a database event set that contains the CreateTable event only.
DatabaseEventSet databaseCreateEventSet = new DatabaseEventSet();
databaseCreateEventSet.CreateTable = true;
//Create a server event handler and set it to the first event handler subroutine.
ServerEventHandler serverCreateEventHandler;
serverCreateEventHandler = new ServerEventHandler(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.
DatabaseEventSet databaseDropEventSet = new DatabaseEventSet();
databaseDropEventSet.DropTable = true;
//Create a server event handler and set it to the second event handler subroutine.
ServerEventHandler serverDropEventHandler;
serverDropEventHandler = new ServerEventHandler(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.
Table tb;
tb = new Table(db, "Test_Table");
Column mycol1;
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 occured.
int x;
int y;
for (x = 1; x <= 1000000000; x++) {
y = x * 2;
}
//Stop event handling.
db.Events.StopEvents();
}