ID do artigo: 195489 - Última revisão: quinta-feira, 6 de julho de 2006 - Revisão: 2.3

CommandTimeout não herda de tempo limite de conexão

Dica do SistemaEste artigo aplica-se a um sistema operativo diferente do que está a utilizar. Foi desactivado o conteúdo do artigo, que pode não ser relevante para si.

Nesta página

Expandir tudo | Recolher tudo

Sintomas

Se CommandTimeout propriedade de uma conexão estiver definida para algum valor e um objeto de comando é associado a essa conexão, o objeto Command não do retirada a conexão CommandTimeout configuração. Em vez disso, CommandTimeout do objeto Command é definida como sua configuração padrão ou que ele foi definido como antes sendo associado com a conexão.

Causa

ActiveX Data Objects (ADO) não praticar herança. Devido ao recurso autônomo de seus objetos, um objeto de comando pode ser associado a mais de um objeto de conexão. A única exceção é a propriedade CursorLocation.

Resolução

Especificamente defina CommandTimeout do objeto de comando.

Situação

Esse comportamento é por design.

Mais Informações

Etapas para reproduzir o comportamento

  1. Inicie um projeto do Visual Basic.
  2. Defina uma referência de projeto ao Microsoft ActiveX Data Objects Library.
  3. Cole o seguinte código no evento Form_Load() do formulário padrão. Você precisará modificar a seqüência de caracteres de conexão para que ele faz referência a um datasouce válido.
          Dim cnn As New ADODB.Connection
          Dim cnstring As String
          cnstring = "Provider = SQLOLEDB;" & _
                     "DATA SOURCE =<server name>;" & _
                     "USER ID = <user id>;" & _
                     "PASSWORD =<password>;" & _
                     "INITIAL CATALOG = <database>;"
          cnn.CommandTimeout = 0
          cnn.Open cnstring
          Dim cmd As New ADODB.Command
          cmd.ActiveConnection = cnn
          Debug.Print "Timeout on Connection: " & cnn.CommandTimeout
          Debug.Print "Timeout on Command:  " & cmd.CommandTimeout
    					
  4. Execute o formulário. Você verá que o tempo limite para o objeto Connection é definido como zero (0) conforme o esperado, enquanto o tempo limite para o objeto de comando é 30 segundos (que é o padrão).

A informação contida neste artigo aplica-se a:
  • Microsoft Data Access Components 1.5
  • Microsoft Data Access Components 2.0
  • Microsoft Data Access Components 2.1 Service Pack 2
  • Microsoft Data Access Components 2.5
  • Microsoft Data Access Components 2.6
  • Microsoft Data Access Components 2.7
  • Microsoft Data Access Components 2.8
Palavras-chave: 
kbmt kbdatabase kbprb KB195489 KbMtpt
Tradução automáticaTradução automática
IMPORTANTE: Este artigo foi traduzido por um sistema de tradução automática (também designado por Machine Translation ou MT), não tendo sido portanto traduzido ou revisto por pessoas. A Microsoft possui artigos traduzidos por aplicações (MT) e artigos traduzidos por tradutores profissionais, com o objetivo de oferecer em português a totalidade dos artigos existentes na base de dados de suporte. No entanto, a tradução automática não é sempre perfeita, podendo conter erros de vocabulário, sintaxe ou gramática. A Microsoft não é responsável por incoerências, erros ou prejuízos ocorridos em decorrência da utilização dos artigos MT por parte dos nossos clientes. A Microsoft realiza atualizações freqüentes ao software de tradução automática (MT). Obrigado.
Clique aqui para ver a versão em Inglês deste artigo: 195489  (http://support.microsoft.com/kb/195489/en-us/ )