datatable 刪除 行

string strQueryString = "select * from gx_xtczy";

            SqlDataAdapter sqlDA = new SqlDataAdapter(strQueryString, sqlConn);
            DataSet ds = new DataSet();
            sqlDA.Fill(ds, "dt1");
            DataTable dt = ds.Tables["dt1"];

            for (int j = 0; j < 3; j++)
            {
                int x = dt.Rows.Count - 1;
                for (int i = 0; i < x ; i++)
                {

                    if (i % 2 == 1)
                    {
                        try
                        {
                            dt.Rows[i].Delete();
                            
                            break;
                        }
                        catch (Exception ex)
                        { }
                    }



                }

            }

代码如上,debug进去发现每次在dt.Rows[i].Delete();后都报异常:
ItemArray“dt.Rows[i].ItemArray”引发了“System.Data.DeletedRowInaccessibleException”类型的异常object[] {System.Data.DeletedRowInaccessibleException}

base异常为:
{"不能通过已删除的行访问该行的信息。"}System.SystemException {System.Data.DeletedRowInaccessibleException}

为什么呢???
换用rows.removeat(i)也是一样的报错。。。。。。。

倒过来删除的代码如下,这次换了removeat方法:

SqlDataAdapter sqlDA = new SqlDataAdapter(strQueryString, sqlConn);
            DataSet ds = new DataSet();
            sqlDA.Fill(ds, "dt1");
            DataTable dt = ds.Tables["dt1"];

            for (int j = 0; j < 4; j++)
            {
                int x = dt.Rows.Count - 1;
                for (int i = x; i >= 0 ; i--)
                {

                    if (i % 2 == 1)
                    {
                        try
                        {
                            //dt.Rows[i].Delete();
                            dt.Rows.RemoveAt(i);
                            break;
                        }
                        catch (Exception ex)
                        { }
                    }



                }

            }


delete方法那段代码达不到目的,。
要用removeat或者remove方法。
要用delete方法的话要在delete前面加一个状态判定。。。。。

DataRowCollection.Remove
当移除行时,该行中的所有数据都将丢失。您还可以调用 DataRow 类的 Delete 方法来标记某行以供移除。调用 Remove 等同于先调用 Delete 再调用 AcceptChanges。

转载于:https://www.cnblogs.com/Nina-piaoye/archive/2007/12/12/991700.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值