FIX: System.ArgumentOutOfRangeException 發生間歇地使用 ADO.NET

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

徵狀

ADO.NET 應用程式中可能會間歇地收到下列的例外狀況錯誤訊息:
System.ArgumentOutOfRangeException: 索引超出範圍。 必須是非負數且小於集合的大小。 參數名稱: 索引

發生的原因

您收到這個錯誤訊息如果您建立或終結相關的資料集物件 (例如 DataView 物件) 在 DataSet 物件的事件處理常式或 DataSet 物件相關聯的物件。比方說這個錯誤已在應用程式,並在其中包含已建立子 DataView 物件為方格的 ListChanged 事件處理常式中的方格控制項中重製。這可讓位置,它應保持靜態基礎 資料集 物件來變更作業期間的內部狀態。

解決方案

支援的 Hotfix 現在可以從 Microsoft,但它只用來修正本文所述的問題。僅適用於發生此特定問題的系統。此 Hotfix 可能會接受其他測試。因此,如果您不會嚴重影響這個問題,我們建議您等候下一個包含此 Hotfix 的 Service Pack。

如果要立即解決這個問題,洽詢 Microsoft 技術支援部以取得該 Hotfix。如需 Microsoft 產品支援服務電話號碼及支援成本的相關資訊的完整清單,請造訪下列 Microsoft 網站]:
http://support.microsoft.com/contactus/?ws=support
附註 在特殊情況下通常會因支援電話所產生的費用可能就不收取如果 Microsoft 支援人員認為某特定更新程式可以解決您的問題。平常的支援成本將會套用到其他支援問題是所做不限定特定有問題的更新程式。此 Hotfix 的英文版具有檔案屬性 (或更新) 中如下表所列。這些檔案的日期和時間為 Coordinated Universal Time (UTC)。當您檢視檔案資訊時,會將它轉換為當地時間。若要到 UTC 與當地時間差異使用 [中日期] 和 [時間] 工具,在 [控制台] 中的 [時區] 索引標籤]。
   Date         Time   Version            Size    File name
   --------------------------------------------------------------
   02-Mar-2004  18:39  1.1.4322.1007   1,294,336  System.data.dll                                             

其他可行方案

請勿建立或摧毀 DataSet 物件的事件處理常式內的資料集相關的物件 (例如 DataView 物件)。

狀況說明

Microsoft 已確認這是本文 < 適用於 > 一節中所列的 Microsoft 產品中的問題。
這個例外狀況呼叫堆疊取決於您的應用程式功能和錯誤的確切原因。以下是 ListChanged 事件處理常式的控制項中建立子 DataView 物件時所發生的兩個範例:

範例呼叫堆疊 1

System.Collections.ArrayList.get_Item(Int32 index)
Sstem.Data.DataTable.RecordStateChanged(Int32 record1, DataViewRowState oldState1, DataViewRowState newState1, Int32 record2, DataViewRowState oldState2, DataViewRowState newState2)
System.Data.DataTable.SetNewRecord(DataRow row, Int32 proposedRecord, DataRowAction action, Boolean isInMerge)
System.Data.DataRow.EndEdit()
System.Data.DataRow.set_Item(DataColumn column, Object value)
System.Data.DataRow.set_Item(String columnName, Object value)

範例呼叫堆疊 2

System.Collections.ArrayList.get_Item(Int32 index)
System.Data.DataTable.ResetIndexes()
System.Data.Merger.MergeTable(DataTable src, DataTable dst)
System.Data.Merger.MergeTableData(DataTable src)
System.Data.Merger.MergeDataSet(DataSet source)
System.Data.DataSet.Merge(DataSet dataSet, Boolean preserveChanges, MissingSchemaAction missingSchemaAction)

附註這些是僅範例,不是唯一的呼叫堆疊,可能會發生這個錯誤。

?考

如需詳細資訊按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
824684用來描述 Microsoft 軟體更新標準術語的說明
取得更多資訊有關所發生的舊版 ADO.NET 類似的例外狀況按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
332215FIX:"System.ArgumentOutOfRangeException: 索引超出範圍 」 與 SqlClient.SqlConnection.Open() 就會發生錯誤
附註微軟知識庫文件 332215 此修正程式已經包含在.NET Framework 1.1 版中。

屬性

文章編號: 836874 - 上次校閱: 2006年6月1日 - 版次: 2.1
這篇文章中的資訊適用於:
  • Microsoft ADO.NET 1.1
關鍵字:?
kbmt kbhotfixserver kbqfe KB836874 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:836874
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。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