首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > .NET > C# >

c#里面datatable删除rows出现错误的有关问题

2011-12-29 
c#里面datatable删除rows出现异常的问题stringstrQueryStringselect*fromgx_xtczy SqlDataAdaptersqlD

c#里面datatable删除rows出现异常的问题
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)也是一样的报错。。。。。。。


[解决办法]
肯定是代码逻辑的错误

报错信息提示的很清楚 当前试图访问的行已删除 说明有删除成功的

但是你回头又去访问已经删除的行 所以就报错了

[解决办法]
在循环中进行删除操作,要倒过来进行操作,防止索引越界。
[解决办法]
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-2)
{
try
{
//dt.Rows[i].Delete();
dt.Rows.RemoveAt(i);
break;
}
catch (Exception ex)
{ }


}

}

热点排行