修正: LOB 資料載入 SQL Server 2008 R2、 SQL Server 2012年或 SQL Server 2008年中考慮改用 SQL 變數時發生資料損毀

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

在此頁中

徵狀

當您執行查詢,其中包含大型物件 (LOB) 資料載入至 Microsoft SQL Server 2008年,Microsoft SQL Server 2012年或 Microsoft SQL Server 2008 R2 中考慮改用 SQL 變數時,就會發生資料損毀。比方說,您可以執行下列查詢將 XML 資料從資料庫資料行複製至 XML 變數:
Declare @OUTXML as XML
SELECT @OUTXML = DataXml FROM Table_1 WHERE id=1 

在此情況下,當其他執行緒嘗試更新相同的 XML 資料行時,會執行SELECT陳述式。這種行為可能會造成資料損毀。此外,您收到下列錯誤訊息之一,當您執行任何的讀取和寫入作業已損毀的 XML 資料行上:
  • XML 資料型別已損毀。
  • 發生未預期的檔案結尾。
注意
  • 在高並行載入作業期間通常會發生問題。
  • 當您使用 「 記錄讀取器代理程式 」 是交易式複寫的發行集發行項清單的一部分的資料表中讀取已損毀的 XML 資料時,您會收到下列錯誤訊息:

    XML 資料型別已損毀。(來源: MSSQLServer,錯誤代碼: 6611)

發生的原因

LOB 資料行上的鎖定被釋放,才能 LOB 資料從資料庫資料行複製到 LOB 資料型別變數,就會發生這個問題。複製程序完成之前在複製過程,同時發生的任何查詢可以更新相同的 LOB 資料。因此,就會發生資料損毀。

解決方案

累積更新資訊

對於 SQL Server 2012年累積的更新 7

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

累積更新 12 個 SQL Server 2008 R2 Service Pack 1

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

累積更新 10 個 SQL Server 2008 Service Pack 3

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

對於 SQL Server 2008 R2 Service Pack 2 (SP2) 的累積更新 5

這個問題的修正程式首次發表累積更新 5] 中。如需有關如何取得此累積更新套件,SQL Server 2008 R2 S2008 R2 sp2 的詳細資訊,請按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
2797460 SQL Server 2008 R2 S2008 R2 SP2 的累積更新套件 5
附註 由於組建便是累計的每個新的修正版本包含的所有 hotfix,並且所有安全性修正程式是隨附於前一 SQL Server 2008 R2 S2008 R2 SP2 的都修正版本。我們建議您考慮將套用最新的修正程式版本,其中包含此 hotfix。如需詳細資訊,按一下下面的文件編號,檢視「Microsoft 知識庫」中的文件:
2730301 SQL Server 2008 R2 建置 SQL Server 2008 R2 Service Pack 2 已發行之後所發行,

狀況說明

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


屬性

文章編號: 2803994 - 上次校閱: 2013年4月15日 - 版次: 3.0
這篇文章中的資訊適用於:
  • Microsoft SQL Server 2008 R2 Service Pack 2
  • Microsoft SQL Server 2008 R2 Developer
  • Microsoft SQL Server 2008 R2 Enterprise
  • Microsoft SQL Server 2008 R2 Standard
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Express
  • Microsoft SQL Server 2008 Web
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Workgroup
  • Microsoft SQL Server 2012 Developer
  • Microsoft SQL Server 2012 Enterprise
  • Microsoft SQL Server 2012 Express
  • Microsoft SQL Server 2012 Standard
  • Microsoft SQL Server 2012 Web
  • SQL Server 2012 Enterprise Core
關鍵字:?
kbqfe kbfix kbsurveynew kbexpertiseadvanced kbmt KB2803994 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:2803994
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