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

文章翻譯 文章翻譯
文章編號: 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 - 上次校閱: 2004年7月14日 - 版次: 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
關鍵字:?
kbmt kbmdacnosweep kboracle kbprb KB251238 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:251238
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。

提供意見

 

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