A Microsoft distribui o Microsoft SQL Server 2008 Service Pack 3 (SP3), o Microsoft SQL Server 2008 R2 ou o Microsoft SQL Server 2012 corre como um ficheiro transferível. Como as correções são cumulativas, cada nova versão contém todos os hotfixes e todas as correções de segurança que foram incluídas com o anterior SqL Server 2008 Service Pack 3 (SP3), SQL Server 2008 R2 ou SQL Server 2012.
Sintomas
Assuma que tem uma aplicação de cliente que usa o método SqlConnection.GetSchema para recuperar as informações de esquema de uma tabela. Esta tabela inclui um nome de coluna que contém um período (.). Por exemplo, um dos nomes da coluna na tabela é "Coluna1.A". Nesta situação, falta a coluna cujo nome contém um período dos resultados que o método SqlConnection.GetSchema retorna.Nota Este problema não ocorre quando utiliza o método OleDbConnection.GetSchema.
Causa
Para avaliar as permissões para colunas, o SqL Server 2008 Service Pack 1 utiliza a função HAS_PERMS_BY_NAME em vez da função PERMISSS na vista do sistema sys.spt_columns_view_managed. No entanto, se um nome de coluna contiver um período e não estiver incluído na função QUOTENAME, a função HAS_PERMS_BY_NAME considera que o utilizador não tem permissões suficientes para essa coluna. Portanto, o problema que é mencionado na secção "Sintomas" ocorre.
Resolução
Informação de atualização cumulativa
Sql Server 2008 R2 Service Pack 2
A correção para este problema foi lançada pela primeira vez na Cumulativa Update 1 para SQL Server 2008 R2 Service Pack 2. Para obter mais informações sobre como obter este pacote de atualização cumulativa, clique no seguinte número de artigo para ver o artigo na Base de Conhecimento da Microsoft:
2720425 Pacote de atualização cumulativo 1 para SQL Server 2008 R2 Service Pack 2Nota 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 R2008 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:
2730301 O SQL Server 2008 R2 constrói que foram lançados após o lançamento do SQL Server 2008 R2 Service Pack 2
SQL Server 2012
A correção para este problema foi lançada pela primeira vez na Cumulativa Update 2 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:
2703275 Pacote de atualização cumulativo 2 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.
Sql Server 2008 R2 Service Pack 1
A correção para este problema foi lançada pela primeira vez na Cumulativa Update 7 para SQL Server 2008 R2 Service Pack 1. Para obter mais informações sobre como obter este pacote de atualização cumulativa, clique no seguinte número de artigo para ver o artigo na Base de Conhecimento da Microsoft:
2703282 Pacote de atualização cumulativo 7 para SQL Server 2008 R2 Service Pack 1Nota 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 R2008 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 Service Pack 1
SQL Server 2008 R2
A correção para este problema foi lançada pela primeira vez na Atualização Cumulativa 13. Para obter mais informações sobre como obter este pacote de atualização cumulativa para SQL Server 2008 R2, clique no seguinte número de artigo para ver o artigo na Base de Conhecimento da Microsoft:
2679366 Pacote de atualização cumulativa 13 para SQL Server 2008 R2 Nota 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 R2008 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:
981356 O SQL Server 2008 R2 constrói que foram lançados após o lançamento do SQL Server 2008 R2
Pacote de atualização cumulativo 4 para SQL Server 2008 SP3
A correção para este problema foi lançada pela primeira vez na Atualização Cumulativa 4. Para obter mais informações sobre como obter este pacote de atualização cumulativa para o SQL Server 2008 Service Pack 4, clique no seguinte número de artigo para ver o artigo na Base de Conhecimento da Microsoft:
2673383 Pacote de atualização cumulativo 4 para SQL Server 2008 Service Pack 3Nota 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 do SqL Server 2008 Service Pack 4. 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:
2629969 SQL Server 2008 constrói que foram lançadas após o lançamento do SQL Server 2008 Service Pack 3
Mais Informações
Para mais informações sobre o método SqlConnection.GetSchema, visite o seguinte website da MSDN:
Estado
A Microsoft confirmou que este problema ocorre nos produtos da Microsoft listados na secção "Aplica-se a".