修正: 錯誤的結果時的 SqlConnection.GetSchema 方法會擷取 SQL Server 2008年中某個資料表的結構描述資訊

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

在此頁中

Microsoft 會將單一可下載檔案 Microsoft SQL Server 2008 Service Pack 3 (SP3) 修正程式。因為的修正程式是累積的每個新版本包含的所有 hotfix,並且隨附於前一個 SQL Server 2008 Service Pack 3 (SP3) 的所有安全性修正都修正版本。

徵狀

假設您已使用的用戶端應用程式 SqlConnection.GetSchema 若要擷取資料表的結構描述資訊的方法。此表格包含的資料行名稱包含句號 (.)。例如,資料行名稱是"Column1.A"。在此情況下,包含一段時間的資料行中沒有結果, SqlConnection.GetSchema 方法會傳回。

附註 當您使用時不會發生這個問題 OleDbConnection.GetSchema 方法。

發生的原因

使用 SQL Server 2008 Service Pack 1 HAS_PERMS_BY_NAME 而不是函式 權限 在發揮作用 sys.spt_columns_view_managed 若要評估的資料行的權限的系統檢視。然而,如果資料行名稱含有句點,且不包括 QUOTENAME 函式, HAS_PERMS_BY_NAME 函式會將視為使用者具有足夠的權限給該資料行。因此,就會發生 「 徵狀 〉 一節所描述的問題。

解決方案

累積更新資訊

SQL Server 2008 SP3 的累積更新套件 4

這個問題的修正程式首次發表累積更新 4] 中。如需有關如何取得此累積更新套件的 SQL Server 2008 Service Pack 4 的詳細資訊,請按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
2673383 SQL Server 2008 Service Pack 3 的累積更新套件 4
附註 因為組建是累計的每個新的修正程式版本會包含所有的快速補充程式,並隨附於前一個 SQL Server 2008 Service Pack 4 的所有安全性修正都修正版本。我們建議您考慮將套用最新的修正程式版本,其中包含此 hotfix。如需詳細資訊,按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
2629969 SQL Server 2008 SQL Server 2008 Service Pack 3 發行之後所發行的組建

其他相關資訊

如需詳細資訊 SqlConnection.GetSchema 方法中,請造訪下列 MSDN 網站:
SqlConnection.GetSchema 方法的一般資訊

狀況說明

Microsoft 已確認這是"適用於 」 一節所列出的 Microsoft 產品中的問題。

屬性

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

提供意見