CORRECÇÃO: Mensagem de erro quando executa uma consulta que contém cláusulas de XML FOR aninhadas no SQL Server 2005: ? O tipo de dados XML está danificado ?

Traduções de Artigos Traduções de Artigos
Artigo: 933808 - Ver produtos para os quais este artigo se aplica.
Erro: # 50000918 (correcção SQL)
Importante
A Microsoft distribui correcções Microsoft SQL Server 2005 como um ficheiro transferível. Uma vez que as correcções são cumulativas, cada nova versão contém todas as correcções e todas as correcções de segurança incluídas com o SQL Server 2005 anterior corrigir lançamento.
Expandir tudo | Reduzir tudo

Nesta página

Sumário

Este artigo descreve o seguinte sobre esta versão de correcção:
  • Problemas corrigidos pelo pacote de correcção
  • Pré-requisitos para instalar o pacote de correcções
  • Se tem de reiniciar o computador depois de instalar o pacote de correcção
  • Se o pacote de correcções é substituído por qualquer outro pacote de correcção
  • Se terá de efectuar quaisquer alterações de registo
  • Ficheiros contidos no pacote de correcção

Sintomas

Quando executa uma consulta que contém cláusulas de XML FOR aninhadas no SQL Server 2005, receberá a seguinte mensagem de erro:
Msg 6611, nível de 16, estado 1, linha 2
O tipo de dados XML está danificado.
Este problema ocorre caso se verifiquem as seguintes condições:
  • As cláusulas de XML FOR use a diretiva TYPE.
  • Especificar uma consulta XQuery contra o tipo de dados XML devolvido pela consulta.
  • Na consulta XQuery, referência QNames na parte superior da cláusula FOR XML.

Resolução

Informações sobre a actualização cumulativa

Para resolver este problema, obtenha o pacote de actualização cumulativa para o SQL Server 2005 Service Pack 2 (compilação 3161). Para mais informações sobre como obter o cumulativa pacote (compilação 3161) de actualização, clique no número de artigo que se segue para visualizar o artigo na base de dados de conhecimento da Microsoft:
935356O pacote de actualização cumulativa (compilação 3161) para o SQL Server 2005 Service Pack 2 está disponível

Informações sobre a correcção

Está disponível a partir da Microsoft uma correcção suportada. No entanto, esta correcção destina-se a corrigir o problema descrito neste artigo. Aplique esta correcção apenas em sistemas que tenham este problema específico. Esta correcção poderá submetida a testes adicionais. Por conseguinte, se não estiver a ser gravemente afectado por este problema, recomendamos que aguarde pela próxima actualização de software que contenha esta correcção.

Se a correcção está disponível para transferência, existe uma secção "denominada transferência de correcção disponível" na parte superior deste artigo da base de dados de conhecimento. Se esta secção não for apresentado, contacte o serviço de cliente do Microsoft e suporte para obter a correcção.

Nota Se ocorram problemas adicionais ou se for necessária qualquer resolução de problemas, poderá ter de criar um pedido de assistência separado. Os custos normais do suporte serão aplicados a problemas adicionais e questões de suporte que não se enquadrem esta correcção específica. Para obter uma lista completa dos números de telefone do suporte de cliente do Microsoft ou para criar um pedido serviço separado, visite o seguinte Web site da Microsoft:
http://support.microsoft.com/contactus/?ws=support
Nota O formulário "Transferência de correcção disponível" apresenta os idiomas para a qual a correcção está disponível. Se não vir o idioma, é porque uma correcção não está disponível para esse idioma.

Pré-requisitos

  • SQL Server 2005 Service Pack 2
    Para obter mais informações sobre como obter o SQL Server 2005 Service Pack 2, clique no número de artigo que se segue para visualizar o artigo na Microsoft Knowledge Base:
    913089Como obter o service pack mais recente para o SQL Server 2005

Informações sobre reinício

Não é necessário reiniciar o computador depois de aplicar esta correcção.

Informações de registo

Não é necessário alterar o registo.

Informações sobre ficheiros da correcção

Esta correcção contém apenas os ficheiros necessários para corrigir os problemas referidos neste artigo. Esta correcção não pode conter de todos os ficheiros que necessita para actualizar completamente um produto para a compilação mais recente.A versão inglesa desta correcção tem os atributos de ficheiro (ou atributos de ficheiro posteriores) listados na seguinte tabela. As datas e horas destes ficheiros são indicadas na hora universal coordenada (UTC). Quando visualiza as informações do ficheiro, é convertido para a hora local. Para determinar a diferença entre a UTC e a hora local, utilize o separador fuso horário no item data e hora no painel de controlo.
Versão do SQL Server 2005 32 bits
Reduzir esta tabelaExpandir esta tabela
Nome de ficheiroVersão do ficheiroTamanho do ficheiroDataTempoPlataforma
Microsoft.SQLServer.maintenanceplantasks.dll9.0.3155.0296,30413-Mar de 200714: 12x 86
Msmdlocal.dll9.0.3155.015,930,22413-Mar de 200714: 12x 86
Mssqlsystemresource.ldfNão aplicável524,28813-Mar de 200711: 11Não aplicável
Mssqlsystemresource.mdfNão aplicável40,173,56813-Mar de 200711: 11Não aplicável
Rdistcom.dll2005.90.3155.0644,46413-Mar de 200714: 12x 86
Sqlaccess.dll2005.90.3155.0350,57613-Mar de 200714: 12x 86
Sqlservr.exe2005.90.3155.029,192,56013-Mar de 200714: 12x 86
SQL Server 2005 x 64 versão
Reduzir esta tabelaExpandir esta tabela
Nome de ficheiroVersão do ficheiroTamanho do ficheiroDataTempoPlataforma
Microsoft.SQLServer.maintenanceplantasks.dll9.0.3155.0296,30413-Mar de 200714: 12x 86
Msmdlocal.dll9.0.3155.015,930,22413-Mar de 200714: 12x 86
Mssqlsystemresource.ldfNão aplicável524,28813-Mar de 200711: 11Não aplicável
Mssqlsystemresource.mdfNão aplicável40,173,56813-Mar de 200711: 11Não aplicável
Rdistcom.dll2005.90.3155.0828,27213-Mar de 200719: 19x 64
Sqlaccess.dll2005.90.3155.0357,74413-Mar de 200719: 19x 86
Sqlservr.exe2005.90.3155.038,577,00813-Mar de 200719: 19x 64
Versão da arquitectura Itanium do SQL Server 2005
Reduzir esta tabelaExpandir esta tabela
Nome de ficheiroVersão do ficheiroTamanho do ficheiroDataTempoPlataforma
Microsoft.SQLServer.maintenanceplantasks.dll9.0.3155.0296,30413-Mar de 200714: 12x 86
Msmdlocal.dll9.0.3155.049,815,92013-Mar de 200720: 35IA-64
Mssqlsystemresource.ldfNão aplicável524,28813-Mar de 200711: 11Não aplicável
Mssqlsystemresource.mdfNão aplicável40,173,56813-Mar de 200711: 11Não aplicável
Rdistcom.dll2005.90.3155.01,885,04013-Mar de 200720: 35IA-64
Sqlaccess.dll2005.90.3155.0352,11213-Mar de 200720: 35x 86
Sqlservr.exe2005.90.3155.072,547,18413-Mar de 200720: 35IA-64

Ponto Da Situação

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

Mais Informação

Para obter mais informações sobre o esquema de atribuição de nomes para as actualizações do SQL Server, clique no número de artigo que se segue para visualizar o artigo na Microsoft Knowledge Base:
822499Novo esquema de atribuição de nomes de ficheiros para pacotes de actualização de software do Microsoft SQL Server

Para obter mais informações sobre a terminologia de actualização de software, clique no número de artigo que se segue para visualizar o artigo na Microsoft Knowledge Base:
824684Descrição da terminologia padrão utilizada para descrever actualizações de software da Microsoft

Passos para reproduzir o problema

  1. Abra o SQL Server Management Studio e, em seguida, crie uma nova consulta.
  2. Run the following statements:
    CREATE TABLE [dbo].[TABLE0](
    	[COL0] [int] NULL,
    	[COL1] [varchar](50) NULL,
    	[COL2] [varchar](50) NULL,
    	[COL3] [varchar](50) NULL,
    	[COL4] [varchar](50) NULL,
    	[COL5] [varchar](50) NULL,
    	[COL6] [varchar](50) NULL,
    	[COL7] [varchar](50) NULL,
    	[COL8] [varchar](50) NULL
    ) ON [PRIMARY]
    
    CREATE TABLE [dbo].[TABLE1](
    	[COL0] [int] NULL,
    	[COL1] [int] NULL,
    	[COL2] [varchar](50) NULL,
    	[COL3] [varchar](50) NULL,
    	[COL4] [varchar](50) NULL,
    	[COL5] [varchar](50) NULL,
    	[COL6] [varchar](50) NULL,
    	[COL7] [varchar](50) NULL,
    	[COL8] [varchar](50) NULL
    ) ON [PRIMARY]
    GO
    
    -- Populating tables
    
    DECLARE @X INT, @Y INT
    SET @X=0
    WHILE @X < 20
      BEGIN
    	INSERT TABLE0 VALUES(@X,'DATAFORCOLUMN1','DATAFORCOLUMN2','DATAFORCOLUMN3','DATAFORCOLUMN4','DATAFORCOLUMN5','DATAFORCOLUMN6','DATAFORCOLUMN7','DATAFORCOLUMN8')
    	SET @Y=0
    	WHILE @Y < 20
    	  BEGIN
    		INSERT TABLE1 VALUES(@X,@Y,'DATAFORCOLUMN2','DATAFORCOLUMN3','DATAFORCOLUMN4','DATAFORCOLUMN5','DATAFORCOLUMN6','DATAFORCOLUMN7','DATAFORCOLUMN8')
    		SET @Y=@Y+1
    	  END
        SET @X=@X+1
      END
    
    -- 
    
    SELECT
    (
         SELECT TABLE0.COL0,
    		    TABLE0.COL1,
    			TABLE0.COL2,
                TABLE0.COL3,
                TABLE0.COL4,
                TABLE0.COL5,
                TABLE0.COL6,
                TABLE0.COL7,
                TABLE0.COL8,
                (           
                      SELECT 
                            TABLE1.COL0,
                            TABLE1.COL1,
                            TABLE1.COL2,
                            TABLE1.COL3,
                            TABLE1.COL4,
                            TABLE1.COL5,
                            TABLE1.COL6,
                            TABLE1.COL7,
                            TABLE1.COL8
                      FROM TABLE1
                      WHERE TABLE0.COL0=TABLE1.COL0
                              FOR XML PATH('RECORDS'), ROOT('TABLE1'),TYPE   
                ) 
          FROM
                TABLE0 FOR XML PATH('RECORDS'), ROOT('TABLE0'),TYPE         
    ).query
    ('
          for $record in /TABLE0/RECORDS/TABLE1/RECORDS
          return
                <OUTPUTXML>
                      {$record/../../COL0}
                      {$record/COL1}
                </OUTPUTXML>
    ')
    

Propriedades

Artigo: 933808 - Última revisão: 20 de novembro de 2007 - Revisão: 1.4
A informação contida neste artigo aplica-se a:
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL 2005 Server Enterprise
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
  • Microsoft SQL 2005 Server Workgroup
Palavras-chave: 
kbmt kbautohotfix kbpubtypekc kbqfe kbhotfixserver kbfix kbsql2005engine kbexpertiseadvanced KB933808 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 revisto ou traduzido por humanos. A Microsoft tem artigos traduzidos por aplicações (MT) e artigos traduzidos por tradutores profissionais. O objectivo é simples: oferecer em Português a totalidade dos artigos existentes na base de dados do suporte. Sabemos no entanto que a tradução automática não é sempre perfeita. Esta pode conter erros de vocabulário, sintaxe ou gramática? erros semelhantes aos que um estrangeiro realiza ao falar em Português. A Microsoft não é responsável por incoerências, erros ou estragos realizados na sequência da utilização dos artigos MT por parte dos nossos clientes. A Microsoft realiza actualizações frequentes ao software de tradução automática (MT). Obrigado.
Clique aqui para ver a versão em Inglês deste artigo: 933808

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