Compartilhar via


Usando modo de captura

Os programas SMO podem capturar e registrar as instruções Transact-SQL equivalentes emitidas pelo programa no lugar 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 mantidos no buffer de captura.

Habilitando o modo de captura no Visual C#

Este exemplo de código habilita o modo de captura e exibe os comandos Transact-SQL mantidos 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 ( String p_s in srv.ConnectionContext.CapturedSql.Text ) {   
   Console.WriteLine(p_s);   
}   
// Execute the captured statements.   
srv.ConnectionContext.ExecuteNonQuery(srv.ConnectionContext.CapturedSql.Text);   
// Revert to immediate execution mode.   
srv.ConnectionContext.SqlExecutionModes = SqlExecutionModes.ExecuteSql;   
}