.NET里面datatable.rows[i]可以直接转换为DataRow吗?是否要先new一个DataRow,然后再依次赋值?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了.NET里面datatable.rows[i]可以直接转换为DataRow吗?是否要先new一个DataRow,然后再依次赋值?相关的知识,希望对你有一定的参考价值。

datatable.Rows是DataRowCollection,而DataRowCollection本身就是DataRow的集合,所以,对集合中的每个元素来说,都是DataRow对象。但是在.Net中,datatable.Rows[i]这种方式获取到的DataRow对象是只读的,也就是只能读取,而不为赋值,即datatable.Rows[i] = new DataRow(),是会报错的,要为datatable.Rows[i]赋值,我们可以这样做,DataRow row = datatable.Rows[i];row = new DataRow来操作。 参考技术A 可以,不信的话,把鼠标移到datatable.rows[i]的rows[i]上,看它返回的是什么类型的,没猜错,肯定是DataRow类型的,要学会学习技巧啊,软件这行要多尝试,才能记得深 参考技术B DataTable.Rows对象本身就是DataRow的集合,所以完全可以DataRow row=datatable.rows[i];这样来定义DataRow对象
你为何要定义DataRow对象呢?你想做什么呢?
一般操作数据表对象还是用DataView更为方便,并且节省资源
参考技术C 你是不是想要这个Row啊 单独对Row操作而不是dt里面的ROW操作啊,如果是这样的话就是
DataRow dr = datatable.rows[i].Copy();
参考技术D datatable.rows[i] 本身就是一个datarow本回答被提问者采纳

C#中删除DataTable中的行的方法

1、在C#中,如果要删除DataTable中的某一行,大约有以下几种办法:

•使用DataTable.Rows.Remove(DataRow),或者DataTable.Rows.RemoveAt(index);可以直接删除行
•datatable.Rows[i].Delete()。Delete()之后需要datatable.AccepteChanges()方法确认完全删除,因为Delete()只是将相应列的状态标志为删除,还可以通过datatable.RejectChanges()回滚,使该行取消删除。
•在删除DataTable中的行的时候,每删除一行,DataTable中所有行的索引都会发生改变。在循环删除DataTable.Row的时候不能使用foreach。使用foreach进行循环的时候,是不允许Table有删除和添加操作的。
•如果是按某列为条件进行删除,则每删完一行,整个Table的index就会立即发生变化,等于Table已经变成了一个新的表。但是索引却已经加1了。于是会造成第一列永远匹配不到。因此,每删除完一行,要跟着判断第一行是否满足删除条件。
•如果要删除DataTable中的多行,应该采用倒序循环DataTable.Rows。因为正序删除时索引会发生变化。程式发生异常,很难预料后果。(不要在循环里使用myDataTable.Rows.RemoveAt(i).因为每删除一行后.i的值会增加,但行数会是减少了.这么做一定会出错.因此要遍历数据,使用Remove方式时,要倒序的遍历)

int count = ds.Tables[0].Rows.Count;
for (int i = count -1; i >=0; i--)

ds.Tables[0].Rows.RemoveAt(i);
}

 

总结:

delete和remove

•Delete的使用是 datatable.Rows[i].Delete();
•Remove的使用是datatable.Rows.Remove(datatable.Rows[i]);
•这两个的区别是,使用delete后,只是该行被标记为deleted,但是还存在,用Rows.Count来获取行数时,还是删除之前的行数.需要使用datatable.AcceptChanges()方法来提交修改.
而Remove方法则是直接删除.(有时候发现使用ds.Tables[0].Rows[i].Delete();数据行也被直接删除了,原因是在创建datatable时没有执行AcceptChanges这个方法,那么在delete时,不会标记,会直接删除掉。)
•如果在for循环里删除行的话,最好是使用delete方法,不然会出现count变化的情况.循环完后再使用AcceptChanges()方法提交修改,删除掉标记为deleted的行

以上是关于.NET里面datatable.rows[i]可以直接转换为DataRow吗?是否要先new一个DataRow,然后再依次赋值?的主要内容,如果未能解决你的问题,请参考以下文章

循环删除DataTable.Row中的多行问题

Datatable删除行的Delete和Remove方法

ADO.NET: 如何将一个DataTable中的行批量复制到另一个表中?

C#中删除DataTable中的行的方法

如何提取DataTable中的某一列字段的所有数据,进行运算

如何将数组写入数据表中的不同列?