PRB: 分散式的查詢會傳回錯誤 7356 與 MSDAORA

重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。

按一下這裡查看此文章的英文版本:251238
本文已封存。本文係以「現狀」提供且不會再更新。
徵狀
如果在執行階段變更中繼資料資訊,發生下列錯誤:
伺服器: 訊息 7356、 層級 16,狀態 1、 第 1 行
OLE DB 提供者 'MSDAORA' 提供的資料行的中繼資料不一致。
當您使用 SQL Server 中參考檢視表,如果您在下列情況下建立在 Oracle 中基礎資料表的分散式的查詢時,可能會發生此錯誤:
  • 您沒有在 CREATE TABLE 陳述式中指定空值屬性。 -以及-

  • 建立主索引鍵使用 ALTER TABLE 陳述式-以及-

  • 您建立包含主索引鍵的檢視。
發生的原因
為 DBSCHEMA_COLUMNS IDBSchemaRowset::GetRowset 傳回 IS_NULLABLE 做為 TRUE。

在列集合上 IColumnsInfo::GetColumnInfo 會傳回 DBCOLUMNFLAGS_ISNULL,做為 FALSE。

因為這些的分散式的查詢失敗,因 7356 錯誤的差異。

OLE DB 提供者 Msdaora.dll,傳回錯誤的資訊,因為 Oracle 傳回中繼資料不正確。

解決方案
期間 CREATE TABLE 陳述式明確地指定資料行的 Null 屬性。
狀況說明
這種行為是經過設計規劃的。
其他相關資訊

重製行為的步驟

使用這些步驟來重現這個問題:
  1. 建立使用此程式碼的測試資料表:
    CREATE TABLE MYDIST      (GMI_ID  VARCHAR2(8)      ,LAST_NAME VARCHAR2(20)      ,FIRST_NAME VARCHAR2(20) )					
  2. 改變使用這個程式碼的資料表:
       ALTER TABLE MYDIST      ADD (CONSTRAINT MYDIST_PK PRIMARY KEY (GMI_ID))					
  3. 使用此程式碼在資料表中插入資料:
       INSERT INTO MYDIST VALUES ('test1','row','one')   INSERT INTO MYDIST VALUES ('test2','row','two')					
  4. 建立使用此檢視:
       CREATE VIEW V_MYDIST1 AS      SELECT GMI_ID FROM MYDIST					
  5. 建立使用 msdaora.dll 檔案的連結的伺服器項目,並執行下列查詢:
    select * from <OracleLinkedServer>..<SchemaName>.V_MYDIST1					
    查詢將傳回這個錯誤:
    伺服器: 訊息 7356、 層級 16,狀態 1、 第 1 行
    OLE DB 提供者 'MSDAORA' 提供的資料行的中繼資料不一致。 在執行階段已經變更中繼資料資訊。

警告:本文為自動翻譯

內容

文章識別碼:251238 - 最後檢閱時間:12/05/2015 18:16:44 - 修訂: 3.2

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

  • kbnosurvey kbarchive kbmt kbmdacnosweep kboracle kbprb KB251238 KbMtzh
意見反應