从 DataTable 对象中删除 DataRow 对象 遇到的问题

我用DataTable的DataRow.Delete方法从表中删除一行时,界面是自动更新了(移除了刚才删除的行),DataRow.Count减了1,但是这时再次循环访问该DataTable,则抛出“不能通过已删除的行访问。。。”异常。在调试状态下查看DataTable删除操作后的数据显示,刚才删除行的位置确实没有数据,但该行并没有真正的删除,仍然占据着位置,所以再次循环访问到这行的时候会抛出异常。
      
      用于从 DataTable 对象中删除 DataRow 对象的方法有两种:DataRowCollection 对象的 Remove 方法和 DataRow 对象的 Delete 方法。Remove 方法从 DataRowCollection 中删除 DataRow,而 Delete 方法只将行标记为删除。当应用程序调用 AcceptChanges 方法时,才会发生实际的删除。通过使用 Delete,您可以在实际删除之前先以编程方式检查哪些行标记为删除。如果将行标记为删除,其 RowState 属性会设置为 Deleted。

      在将 DataSet 或 DataTable 与 DataAdapter 和关系型数据源一起使用时,用 DataRow 的 Delete 方法移除行。Delete 方法只是在 DataSet 或 DataTable 中将行标记为 Deleted,而不会移除它。而 DataAdapter 在遇到标记为 Deleted 的行时,会执行其 DeleteCommand 方法以在数据源中删除该行。然后,就可以用 AcceptChanges 方法永久移除该行。如果使用 Remove 删除该行,则该行将从表中完全移除,但 DataAdapter 不会在数据源中删除该行。

private   void  DemonstrateDeleteRow()
{
    
// Create a simple DataTable with two columns and ten rows.
    DataTable table = new DataTable("table");
    DataColumn idColumn 
= new DataColumn("id",
        Type.GetType(
"System.Int32"));
    idColumn.AutoIncrement
=true;
    DataColumn itemColumn 
= new DataColumn("item"
        Type.GetType(
"System.String"));
    table.Columns.Add(idColumn);
    table.Columns.Add(itemColumn);

    
// Add ten rows.
    DataRow newRow;
     
    
for(int i = 0; i <10; i++)
    
{
        newRow 
= table.NewRow();
        newRow[
"item"= "Item " + i;
        table.Rows.Add(newRow);
    }

    table.AcceptChanges();

    DataRowCollection itemColumns 
= table.Rows;
    itemColumns[
0].Delete();
    itemColumns[
2].Delete();
    itemColumns[
3].Delete();
    itemColumns[
5].Delete();
    Console.WriteLine(itemColumns[
3].RowState.ToString());

    
// Reject changes on one deletion.
    itemColumns[3].RejectChanges();

    
// Change the value of the column so it stands out.
    itemColumns[3]["item"= "Deleted, Undeleted, Edited";

    
// Accept changes on others.
    table.AcceptChanges();

    
// Print the remaining row values.
    foreach(DataRow row in table.Rows)
    
{
        Console.WriteLine(row[
0+ "/table" + row[1]);
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值