A Microsoft distribui as correções do Microsoft SQL Server 2008 R2 Service Pack 1 (SP1) ou do Microsoft SQL Server 2012 num ficheiro transferível. Como as correções são cumulativas, cada nova versão contém todos os hotfixes e todas as atualizações de segurança que foram incluídas com o anterior SqL Server 2008 R2 Service Pack 1 (SP1) ou o microsoft SQL Server 2012.
Sintomas
Considere o seguinte cenário:
-
Atualize do Microsoft SQL Server 2005 para o Microsoft SQL Server 2008 ou para o Microsoft SQL Server 2008 R2 ou para o Microsoft SQL Server 2012.
-
Você faz uma consulta que usa o procedimento armazenado sp_cursoropen e, em seguida, especifica o parâmetro de contagem de filas para buscar as primeiras linhas de uma tabela.
Neste cenário, o desempenho pode ser mais lento do que se executar a mesma consulta no SQL Server 2005.
Causa
Esta questão ocorre porque o Otimizador de Consulta usa um plano estático de cursor em vez de um plano de cursor dinâmico. Para um plano de cursor estático, o SQL Server pega em todas as linhas e insere-as na mesa de trabalho do cursor. No entanto, para um plano de cursor dinâmico, o SQL Server só recolhe as linhas que são necessárias.
Resolução
Informação de atualização cumulativa
SQL Server 2012
A correção para este problema foi lançada pela primeira vez na Cumulativa Update 1 para o SQL Server 2012. Para obter mais informações sobre este pacote de atualização cumulativa, clique no seguinte número de artigo para ver o artigo na Base de Conhecimento da Microsoft:
2679368 Pacote de atualização cumulativo 1 para SQL Server 2012Nota Como as construções são cumulativas, cada nova versão de correção contém todos os hotfixes e todas as correções de segurança que foram incluídas com o anterior lançamento de correção SQL Server 2012. A Microsoft recomenda que considere aplicar o mais recente lançamento de correção que contém este hotfix. Para mais informações, clique no número de artigo que se segue para ver o artigo na Base de Dados de Conhecimento Microsoft:
2692828 O SQL Server 2012 constrói que foram lançados após o lançamento do SQL Server 2012 Deve aplicar um hotfix SQL Server 2012 a uma instalação do SQL Server 2012.
Pacote de atualização cumulativo 5 para SQL Server 2008 R2 SP1
Depois de aplicar este hotfix, ative o traço da bandeira 4199. A correção para este problema foi lançada pela primeira vez na Atualização Cumulativa 5. Para obter mais informações sobre como obter este pacote de atualização cumulativa para SQL Server 2008 R2 SP1, clique no seguinte número de artigo para ver o artigo na Base de Conhecimento da Microsoft:
2659694 Pacote de atualização cumulativo 5 para SQL Server 2008 R2 SP1Nota Como as construções são cumulativas, cada nova versão de correção contém todos os hotfixes e todas as correções de segurança que foram incluídas com o anterior lançamento de correção R2 SP1 do SQL Server 2008. Recomendamos que considere aplicar o mais recente lançamento de correção que contém este hotfix. Para mais informações, clique no número de artigo que se segue para ver o artigo na Base de Dados de Conhecimento Microsoft:
2567616 O SQL Server 2008 R2 constrói que foram lançados após o lançamento do SQL Server 2008 R2 SP1
Solução
Para contornar esta questão, adicione a sugestão de consulta FAST à consulta.
Mais Informações
Para obter mais informações sobre como usar dicas de consulta, visite o seguinte site da MSDN:
Informações gerais sobre como usar dicas de consultaPara mais informações sobre o traço da bandeira 4199, visite o seguinte site:
Estado
A Microsoft confirmou que este problema ocorre nos produtos da Microsoft listados na secção "Aplica-se a".