注意: 精靈建立 QueryDef 聯結的無效的資料行名稱

文章翻譯 文章翻譯
文章編號: 139996 - 檢視此文章適用的產品。
全部展開 | 全部摺疊

徵狀

如果您使用 AppWizard 或 ClassWizard 建立 MFC DAO 資料錄集] 聯結 (Join) 包含具有相同名稱的資料行的資料表是預先定義查詢 (QueryDef) 為基礎應用程式產生例外狀況嘗試開啟資料錄集時。例外狀況表示:
   '[table.column]' isn't a valid parameter name.
				
資料表和資料行對應到實際的資料表和資料行名稱在您的資料庫中的位置。

附註在 Visual 的 C + + 6.0 中 [AppWizard 建立 CdaoRecordset 衍生的類別,為該查詢為基礎的應用程式。在執行階段您會收到下列錯誤訊息:
名稱 '[table.column]' 的無效 bracketing
附註在 Visual C++.NET 2002年和 Visual C++.NET 2003年,[AppWizard 建立 CRecordset 衍生的類別,為該查詢為基礎的應用程式。在執行階段您會收到下列錯誤訊息:
' ' 不是有效的名稱。 請確定它不包含無效的字元或標點符號,而且不是太長。

發生的原因

由於不正確的方式將在其中精靈分隔的括號參考加入至標準 table_name.column_name CDaoRecordset 衍生類別的 DoFieldExchange,就會擲回之例外狀況。

精靈可產生下列語法:
   [table.column]
				
正確的語法是:
   [table].[column]
				

解決方案

您必須以手動方式修改 DoFieldExchange CDaoRecordset 衍生類別或 CRecordset 衍生類別的修正那些使用不正確的語法的直欄參照。請依照下列步驟執行:
  1. 不要新增限定詞是任何資料行不會複製。限定資料行沒有的模稜兩可 (Ambiguity) 的存在,將會造成錯誤。 如需詳細資訊請參閱 「 Microsoft 知識庫 」 中下列文:
    139994使用 MFC DAO 中的資料行名稱指定資料表名稱
  2. 修改精靈所產生的程式碼,以正確地分隔資料表和資料行名稱。如需有關最後一欄的確切的形式的詳細資訊的參考中有詳細說明,請參閱下列的 「 Microsoft 知識庫 」 中的文件:
    139997項目中找不到這個集合"與 MFC DAO 加入

狀況說明

Microsoft 已確認這是在 Microsoft 中的錯誤,會列在本文開頭的產品。

屬性

文章編號: 139996 - 上次校閱: 2004年1月6日 - 版次: 3.0
這篇文章中的資訊適用於:
  • The AppWizard?應用於:
    • Microsoft Visual C++ 4.0 Standard Edition
    • Microsoft Visual C++ 4.1 Subscription
    • Microsoft Visual C++ 4.2 Enterprise Edition
    • Microsoft Visual C++ 5.0 Enterprise Edition
    • Microsoft Visual C++ 6.0 Enterprise Edition
    • Microsoft Visual C++ 4.2 Professional Edition
    • Microsoft Visual C++ 5.0 Professional Edition
    • Microsoft Visual C++ 6.0 Professional Edition
    • Microsoft Visual C++, 32-bit Learning Edition 6.0
    • Microsoft Visual C++ .NET 2002 Standard Edition
    • Microsoft Visual C++ .NET 2003 Standard Edition
  • The ClassWizard?應用於:
    • Microsoft Visual C++ 4.0 Standard Edition
    • Microsoft Visual C++ 4.1 Subscription
    • Microsoft Visual C++ 4.2 Enterprise Edition
    • Microsoft Visual C++ 5.0 Enterprise Edition
    • Microsoft Visual C++ 6.0 Enterprise Edition
    • Microsoft Visual C++ 4.2 Professional Edition
    • Microsoft Visual C++ 5.0 Professional Edition
    • Microsoft Visual C++ 6.0 Professional Edition
    • Microsoft Visual C++, 32-bit Learning Edition 6.0
    • Microsoft Visual C++ .NET 2002 Standard Edition
    • Microsoft Visual C++ .NET 2003 Standard Edition
關鍵字:?
kbmt kbbug kbdatabase kbpending kbwizard KB139996 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:139996
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