关于DataTable内部索引已损坏的问题 System.Data.RBTree
1、错误提示:
最近,Winform程序在极其偶然的情况下会遇到如下错误提示
Framework 版本: v4.0.30319
说明: 由于未经处理的异常,进程终止。
异常信息: System.InvalidOperationException
堆栈:
在 System.Data.RBTree`1[[System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089]].RBDeleteX(Int32, Int32, Int32)
在 System.Data.RBTree`1[[System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089]].DeleteByIndex(Int32)
在 System.Data.Index.RecordStateChanged(Int32, System.Data.DataViewRowState, System.Data.DataViewRowState, Int32, System.Data.DataViewRowState, System.Data.DataViewRowState)
在 System.Data.DataTable.RecordStateChanged(Int32, System.Data.DataViewRowState, System.Data.DataViewRowState, Int32, System.Data.DataViewRowState, System.Data.DataViewRowState)
在 System.Data.DataTable.SetNewRecordWorker(System.Data.DataRow, Int32, System.Data.DataRowAction, Boolean, Boolean, Int32, Boolean, System.Exception ByRef)
在 System.Data.DataTable.SetNewRecord(System.Data.DataRow, Int32, System.Data.DataRowAction, Boolean, Boolean, Boolean)
在 System.Data.DataRow.EndEdit()
在 System.Data.DataRow.set_Item(System.Data.DataColumn, System.Object)
相信有不少人遇到过这个问题,老王也被这个问题困扰了一个星期了。
差了不少资料,此问题基本与版本无关,因为1.0、1.1、2.0、3.5、4.0、4.5都是可以重现问题的。
2、导致“Datatable 的索引已损坏”发生的原因有四种。
(1)在DataView.ListChanged 事件的时候改变值。这是不支持的。
来看一下调用堆栈,如果你看到DataView.OnListChanged,你正在更改一个DataRow/Set/Table,这时很可能会发生索引损坏(即被DataRow.EndEdit抛出)。
简短描述一下这个问题:内部索引得到编辑out-of-order的消息。
解决方法-使用DataTable.RowChanged事件,而不是DataView.ListChanged事件。
(2)当合并数据到已经存在的DataRow时候仍然有一些没有修复的漏洞, 这个是在Added或者Deleted状态下开始,并在Modified行状态的时候结束。
当 LoadOption.PreserveChanges事件发生时,调用DataAdapter.Fill, DataSet.Load, DataTable.Load事件。
用DataSet.Merge, DataTable.Merge来删除行。
用DataSet.Merge (DataRow[])添加行。
简单描述问题:当DataTable让DataView “添加”而不是“修改”时,导致索引损坏。
(3)多线程
DataSet/ DataTable和任何连接的对象都不是线程安全的。请确保您锁定所有合适的对象。
我的问题属于此类,因为我在多线程中都有操作DataTable,然后,看了这篇帖子,我在所有操作DataTable的地方都加入了Lock语句,然后问题解决了!
感谢此文作者 GR_king,原文网址:http://blog.51cto.com/gleolee/1911134
lock (datatable)
{
针对datatable的操作
}
(4)当DataColumn.DataType是一个引用类型,并且值是被更改而不是被当作只读类型来对待的时候。
例如:DataColumn.DataType是byte []类型和按照列排序的。如果在byte数组中的值改变而不是制定一个新的byte数组给DataRow,
那么内部的索引不知道这样的变化,然后损坏。这是在没有通知内部索引的情况下数据发生改变。
本文非原创,转自:https://blog.csdn.net/deboywang/article/details/84070501
关于DataTable内部索引已损坏的问题 System.Data.RBTree的更多相关文章
- C# 数据库写入Sql Bulk索引损坏异常问题System.InvalidOperationException: DataTable internal index is corrupted: '4'
		
C# 数据库写入Sql Bulk索引损坏异常问题 System.InvalidOperationException: DataTable internal index is corrupted: '4 ...
 - 转:"在已损坏了程序内部状态的XXX.exe 中发生了缓冲区溢出"的一种可能原因
		
我的问题跟原作者的问题差不多.头文件和DLL不匹配导致的. 原文链接:http://blog.csdn.net/u012494876/article/details/39030887 今天软件突然出现 ...
 - Sql Server尝试读取或写入受保护的内存。这通常指示其他内存已损坏
		
今日遇到这样一个问题,用vs2010调试C#代码时,只要代码一运行到跟数据库关联的地方时,编译器就报错误,给的提示如:调试器已附加,要继续需要分离什么的,咋一看还以为是vs中调试器设置的问题,可后来仔 ...
 - SqlServer索引页损坏恢复
		
问题背景 运维操作失误,在没有正常关闭sqlserver的情况下,将服务器关闭了,重启后某些表损坏(应该是某些页损坏了,没有损坏的页还能访问到数据,但是访问损坏了的页就有问题),目前数据库只有4.20 ...
 - 数据库页已标记为 RestorePending,可能表明磁盘已损坏。要从此状态恢复,请执行还原操作。
		
错误提示: 消息 829,级别 21,状态 1,第 1 行 数据库 ID 15,页 (1:21826) 已标记为 RestorePending,可能表明磁盘已损坏.要从此状态恢复,请执行还原操作. 引 ...
 - windows7 Sql server 2012 尝试读取或写入受保护的内存。这通常指示其他内存已损坏的修复
		
项目中,使用了sql server2012数据库,服务端是2012,客户端如果是2008的话,就会报错: 索引错误. 没办法,就安装了sql server2012客户端.但是还是报错,无法连上数据库服 ...
 - 关于C#调用非托管DLL,报“内存已损坏的”坑,坑,坑
		
因客户需求,与第三方对接,调用非托管DLL,之前正常对接的程序,却总是报“内存已损坏的异常”,程序进程直接死掉,折腾到这个点(2018-05-11 00:26),终于尘埃落定,直接上程序. 之前的程序 ...
 - 日常关键字:定时关机、该任务映像已损坏或已篡改.(0x80041321)、ChaZD生词同步扇贝
		
我在床上用chinanet网络慢得简直令人发指,12B/S.是的你没有看错,这是我最常看到的网速.但是我最近发现电脑联网开出一个WiFi,在床上用手机上网时,网速会一点提升,可达到1KB/S(⊙﹏⊙) ...
 - SQL Server Reporting Services:无法检索应用程序文件。部署中的文件已损坏
		
如果在客户端计算机上启动Microsoft SQL Server 2012的 ClickOnce 版本的 Microsoft SQL Server 报表生成器时出现"无法检索应用程序文件.部 ...
 
随机推荐
- mysql参数之innodb_buffer_pool_size大小设置
			
用于缓存索引和数据的内存大小,这个当然是越多越好, 数据读写在内存中非常快, 减少了对磁盘的读写. 当数据提交或满足检查点条件后才一次性将内存数据刷新到磁盘中.然而内存还有操作系统或数据库其他进程使用 ...
 - 【redis】redis异常-MISCONF Redis is configured to save RDB snapshots
			
使用redis报错: MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persis ...
 - Grafana的Docker部署方式
			
docker run -d -p : --name=grafana544 -v D:/grafana/grafana-/data:/var/lib/grafana -v D:/grafana/graf ...
 - Java编程基础——流程控制
			
Java编程基础——流程控制 摘要:本文主要介绍Java编程中的流程控制语句. 分类 流程控制指的是在程序运行的过程中控制程序运行走向的方式.主要分为以下三种: 顺序结构:从上到下依次执行每条语句操作 ...
 - DevExpress的TreeList的常用属性设置以及常用事件
			
场景 Winform控件-DevExpress18下载安装注册以及在VS中使用: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/1 ...
 - 原生js与jquery加载页面元素比较
			
原生js:将获取元素的语句写到页面头部,会因为元素还没有加载而出错,js提供了window.onload 这个方法事先加载元素 <script type="text/javascrip ...
 - 中国爬虫违法违规案例汇总github项目介绍
			
中国爬虫违法违规案例汇总github项目介绍 GitHub - 本项目用来整理所有中国大陆爬虫开发者涉诉与违规相关的新闻.资料与法律法规.致力于帮助在中国大陆工作的爬虫行业从业者了解我国相关法律,避免 ...
 - vue---v-model的详细解答
			
1.v-model:双向数据绑定的实现原理 等同于一个 v-bind 加 v-on <div id="app"> <!-- <input t ...
 - Redis缓存和MySQL数据一致性方案(转)
			
需求起因 在高并发的业务场景下,数据库大多数情况都是用户并发访问最薄弱的环节.所以,就需要使用redis做一个缓冲操作,让请求先访问到redis,而不是直接访问MySQL等数据库. 这个业务场景,主要 ...
 - Java基础回顾一
			
1.JDK和JRE的区别: JDK:java开发工具包,提供java的开发环境和运行环境 JRE:java运行环境,为java的运行提供所需要的环境 2. ==和qruals的区别: == 基本类型: ...