Usando modo de captura
Os programas SMO podem capturar e registrar as instruções Transact-SQL equivalentes emitidas pelo programa no lugar das, ou além das, instruções executadas pelo programa. Você habilita o modo de captura usando o objeto ServerConnection ou a propriedade ConnectionContext do objeto Server.
Exemplo
Para usar qualquer exemplo de código fornecido, será necessário escolher o ambiente de programação, o modelo de programação e a linguagem de programação para criar o aplicativo. Para mais informações, consulte "Como criar um projeto Visual Basic SMO no Visual Studio .NET" ou "Como criar um projeto Visual C# SMO no Visual Studio .NET" nos Manuais Online do SQL Server.
Habilitando o modo de captura no Visual Basic
Este exemplo de código habilita o modo de captura e exibe os comandos Transact-SQL contidos no buffer de captura.
'Connect to the local, default instance of SQL Server.
Dim srv As Server
srv = New Server
'Set the execution mode to CaptureSql for the connection.
srv.ConnectionContext.SqlExecutionModes = SqlExecutionModes.CaptureSql
'Make a modification to the server that is to be captured.
srv.UserOptions.AnsiNulls = True
srv.Alter()
'Iterate through the strings in the capture buffer and display the captured statements.
Dim s As String
For Each s In srv.ConnectionContext.CapturedSql.Text
Console.WriteLine(s)
Next
'Execute the captured statements.
srv.ConnectionContext.ExecuteNonQuery(srv.ConnectionContext.CapturedSql.Text)
'Revert to immediate execution mode.
srv.ConnectionContext.SqlExecutionModes = SqlExecutionModes.ExecuteSql
Habilitando o modo de captura no Visual C#
Este exemplo de código habilita o modo de captura e exibe os comandos Transact-SQL contidos no buffer de captura.
{
//Connect to the local, default instance of SQL Server.
Server srv;
srv = new Server();
//Set the execution mode to CaptureSql for the connection.
srv.ConnectionContext.SqlExecutionModes = SqlExecutionModes.CaptureSql;
//Make a modification to the server that is to be captured.
srv.UserOptions.AnsiNulls = true;
srv.Alter();
//Iterate through the strings in the capture buffer and display the captured statements.
string s;
foreach ( s in srv.ConnectionContext.CapturedSql.Text) {
Console.WriteLine(s);
}
//Execute the captured statements.
srv.ConnectionContext.ExecuteNonQuery(srv.ConnectionContext.CapturedSql.Text);
//Revert to immediate execution mode.
srv.ConnectionContext.SqlExecutionModes = SqlExecutionModes.ExecuteSql;
}