PROBLEMA: Distribuídas erro retornar consultas 7356 com MSDAORA

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

Neste artigo

Sintomas

Se as informações de metadados forem alteradas em tempo de execução, ocorrerá o seguinte erro:
Servidor: Mensagem 7356, nível 16, estado 1, linha 1
Provedor OLE DB 'MSDAORA' forneceu metadados inconsistentes para uma coluna.
Este erro pode ocorrer quando você usa consultas distribuídas no SQL Server que fazem referência a um modo de exibição se você criar a tabela subjacente no Oracle sob as seguintes condições:
  • Você não especificar nulabilidade a instrução CREATE TABLE. - e -

  • Você criar uma chave primária usando a instrução ALTER TABLE - e -

  • Você cria um modo de exibição que inclui o PRIMARY KEY.

Causa

IDBSchemaRowset::GetRowset para DBSCHEMA_COLUMNS retorna IS_NULLABLE como TRUE.

IColumnsInfo::GetColumnInfo no conjunto de linhas retorna DBCOLUMNFLAGS_ISNULL como FALSE.

Devido a essas discrepâncias, falhas de consultas distribuídas com o erro 7356.

O provedor OLE DB, msdaora.dll, retorna as informações erradas porque os metadados que retorna do Oracle estão incorreto.

Resolução

Especifique a condição de nulidade da coluna explicitamente durante a instrução CREATE TABLE.

Situação

Esse comportamento é por design.

Mais Informações

Etapas para reproduzir o problema

Use estas etapas para reproduzir o comportamento:
  1. Criar a tabela de teste usando este código:
    CREATE TABLE MYDIST
          (GMI_ID  VARCHAR2(8)
          ,LAST_NAME VARCHAR2(20)
          ,FIRST_NAME VARCHAR2(20) )
    					
  2. Alterar a tabela usando este código:
       ALTER TABLE MYDIST
          ADD (CONSTRAINT MYDIST_PK PRIMARY KEY (GMI_ID))
    					
  3. Inserir dados na tabela usando este código:
       INSERT INTO MYDIST VALUES ('test1','row','one')
       INSERT INTO MYDIST VALUES ('test2','row','two')
    					
  4. Criar um modo de exibição usando esse:
       CREATE VIEW V_MYDIST1 AS
          SELECT GMI_ID FROM MYDIST
    					
  5. Criar uma entrada de servidor vinculado usando o arquivo msdaora.dll e executar a consulta a seguir:
    select * from <OracleLinkedServer>..<SchemaName>.V_MYDIST1
    					
    a consulta retorna este erro:
    Servidor: Mensagem 7356, nível 16, estado 1, linha 1
    Provedor OLE DB 'MSDAORA' forneceu metadados inconsistentes para uma coluna. Informações de metadados foram alteradas em tempo de execução.

Propriedades

ID do artigo: 251238 - Última revisão: quarta-feira, 14 de julho de 2004 - Revisão: 3.2
A informação contida neste artigo aplica-se a:
  • Microsoft OLE DB Provider for Oracle Server 1.0
  • Microsoft OLE DB Provider for Oracle Server 1.0
  • Microsoft SQL Server 7.0 Standard Edition
  • Microsoft SQL Server 7.0 Service Pack 1
Palavras-chave: 
kbmt kbmdacnosweep kboracle kbprb KB251238 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: 251238

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