Desconectando de uma instância do SQL Server
Não é necessário fechar e desconectar manualmente objetos SMO (Objetos de Gerenciamento de SQL Server). As conexões são abertas e fechadas, conforme o necessário.
Pool de conexões
Quando o método Connect é chamado, a conexão não é liberada automaticamente. O método Disconnect deve ser chamado explicitamente para liberar a conexão com o pool de conexões. Você também pode solicitar uma conexão não inserida no pool. Para isso, defina a propriedade NonPooledConnection da propriedade ConnectionContext que faz referência ao objeto ServerConnection.
Desconectando de uma instância do SQL Server para RMO
O fechamento de conexões de servidor quando você está programando com RMO é um pouco diferente do que quando a programação é feita com SMO.
Como a conexão de servidor para um objeto RMO é mantida pelo ServerConnection objeto , esse objeto também é usado ao se desconectar de uma instância do Microsoft SQL Server quando você programa usando RMO. Para fechar uma conexão usando o objeto ServerConnection, chame o método Disconnect do objeto RMO. Depois que a conexão tiver sido fechada, os objetos RMO não poderão ser usados.
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.
Fechando e desconectando um objeto SMO no Visual Basic
Este exemplo de código mostra como solicitar uma conexão não agrupada definindo a propriedade NonPooledConnection da propriedade de objeto ConnectionContext.
Fechando e desconectando um objeto SMO no Visual C#
Este exemplo de código mostra como solicitar uma conexão não agrupada definindo a propriedade NonPooledConnection da propriedade de objeto ConnectionContext.
{
Server srv;
srv = new Server();
//Disable automatic disconnection.
srv.ConnectionContext.AutoDisconnectMode = AutoDisconnectMode.NoAutoDisconnect;
//Connect to the local, default instance of SQL Server.
srv.ConnectionContext.Connect();
//The actual connection is made when a property is retrieved.
Console.WriteLine(srv.Information.Version);
//Disconnect explicitly.
srv.ConnectionContext.Disconnect();
}