CORREÇÃO: "servidor: Msg 7359" Erro ao executar uma consulta distribuída no SQL Server 2008 ou no SQL Server 2008 R2 se uma versão de esquema é atualizada de mais de cinco vezes

Traduções deste artigo Traduções deste artigo
ID do artigo: 2588970 - Exibir os produtos aos quais esse artigo se aplica.
Expandir tudo | Recolher tudo

Neste artigo

A Microsoft distribui correções de Microsoft SQL Server 2008 Service Pack 2 (SP2) como um arquivo para download. Como as correções são cumulativas, cada versão nova contém todos os hotfixes e lançamento da atualização de todas as atualizações de segurança que foram incluídas com o anterior SQL Server 2008 SP2.

Sintomas

Considere o seguinte cenário:
  • Você pode criar um servidor vinculado em um computador que esteja executando o Microsoft SQL Server 2008 ou Microsoft SQL Server 2008 R2. O servidor vinculado aponta para uma fonte de dados OLE DB em um servidor remoto.
  • Você executa uma consulta distribuída que usa alguns objetos de dados no servidor vinculado.
  • Você realizar algumas operações em um servidor remoto e as operações causam mais de cinco atualizações de versão de esquema nos objetos de dados.

    Por exemplo, você pode reconstruir o índice de uma tabela no servidor remoto para atualizar a versão do esquema da tabela no servidor vinculado.

    Observação Você executa as operações antes da próxima execução da consulta.
  • Você executar novamente a consulta distribuída no servidor vinculado.

Nesse cenário, a consulta não é recompilada e você recebe uma mensagem de erro semelhante à seguinte:
Servidor: Msg 7359, o nível Número do nívelO estado Declarar númeroA linha Número da linha
O provedor do OLE DB"Nome do provedor"para o servidor vinculado"Nome do servidor vinculado"relatou uma alteração na versão do esquema entre (de tempo de compilação"Tempo de compilação") e (tempo de execução"Tempo de execução") para a tabela"Nome da tabela vinculada".
Anotações
  • Nome do provedor é um espaço reservado para o nome do provedor OLE DB.
  • Nome da tabela vinculada é um espaço reservado para o nome da tabela que é consultado no servidor vinculado.
  • As instruções a seguir geralmente podem alterar a versão do esquema:
    • ALTERAR TABELA
    • CRIAR ÍNDICE
    • DESCARTAR ÍNDICE
    • REINDEXAÇÃO DE DBCC

Causa

Esse problema ocorre porque o limite de recompilação de consultas é alcançado.

Quando é feita uma alteração no esquema, alguns objetos no cache são descartados e a consulta exige uma operação de recompilação. No entanto, um limite superior para recompilação for atingido depois de mais de cinco que atualizar a versão de esquema feitas. Portanto, o problema mencionado na seção "Sintomas" ocorre.

Resolução

Informações da atualização cumulativa

Pacote de atualização cumulativa 6 para SQL Server 2008 SP2

A correção para esse problema foi lançada pela primeira vez no pacote de atualização cumulativa 6. Para obter mais informações sobre como obter esse pacote de atualizações cumulativas para SQL Server 2008 SP2, clique no número abaixo para ler o artigo na Base de dados de Conhecimento da Microsoft:
2582285 Pacote de atualização cumulativa 6 para SQL Server 2008 Service Pack 2
Observação Como as compilações são cumulativas, cada nova versão de atualização contém todos os hotfixes e lançamento da atualização de todas as atualizações de segurança que foram incluídas com o anterior SQL Server 2008 SP2. Recomendamos que você considere a aplicação a versão de atualização mais recente que contém esse hotfix. Para obter mais informações, clique no número abaixo para ler o artigo na Base de dados de Conhecimento da Microsoft:
2402659 O SQL Server de 2008 compilações lançadas após o lançamento do SQL Server 2008 SP2



Como Contornar

Para contornar esse problema, use um dos seguintes métodos:
  • Execute o DBCC FREEPROCCACHE('Plan_Handle') instrução.

    Para obter mais informações sobre o Plan_Handle parâmetro, visite o seguinte site da MSDN:
    Informações gerais sobre o parâmetro Plan_Handle
  • Execute o sp_refreshView 'Nomedaexibição' procedimento armazenado.

    Observação Esse método não funciona se o pacote de atualizações cumulativas 3 para SQL Server 2008 SP2 está instalado.

Situação

A Microsoft confirmou que este é um problema nos produtos da Microsoft listados na seção "Aplica-se a".

Propriedades

ID do artigo: 2588970 - Última revisão: segunda-feira, 19 de setembro de 2011 - Revisão: 1.0
A informação contida neste artigo aplica-se a:
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Express
  • Microsoft SQL Server 2008 R2 Datacenter
  • Microsoft SQL Server 2008 R2 Developer
  • Microsoft SQL Server 2008 R2 Enterprise
  • Microsoft SQL Server 2008 R2 Express
  • Microsoft SQL Server 2008 R2 Express with Advanced Services
  • Microsoft SQL Server 2008 R2 Standard
  • Microsoft SQL Server 2008 R2 Workgroup
  • Microsoft SQL Server 2008 Service Pack 1
  • Microsoft SQL Server 2008 Service Pack 2
  • Microsoft SQL Server 2008 Standard
Palavras-chave: 
kbqfe kbfix kbexpertiseadvanced kbsurveynew kbmt KB2588970 KbMtpt
Traduçã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: 2588970

Submeter comentários

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com