免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
DataTable循環(huán)刪除行
       1.如果只是想刪除datatable中的一行,可以用DataRow的delete,但是必須要?jiǎng)h除后讓DataTable知道,所以就要用到.AcceptChanges()方法,原因是這種刪除只是標(biāo)識(shí)性刪除,就像我們通常在數(shù)據(jù)庫(kù)中用到的IsDelete字段。

       2.徹底刪除就要用到datatable的.Rows.Remove(DataRow dr)方法,同理也只是刪除一行可以,如果要循環(huán)刪除請(qǐng)繼續(xù)往下看。

       3.循環(huán)徹底刪除就要用.Rows.RemoveAt(int index)方法,所以如果你是foreach的愛好者,在此請(qǐng)你換換口味,還有如果你是for的i++的忠實(shí)fans也希望你能換個(gè)思維。先看一下上面程序的正向?qū)懛ǎㄥe(cuò)誤的,不可用)

        for (int i = 0, j = dt.Rows.Count; i < j; i++)
        {
            
if (Convert.ToInt32(dt.Rows[i]["RowID"]) == RowID)
                dt.Rows.RemoveAt(i);
        }
 

  這個(gè)的錯(cuò)誤在于datatable的RemoveAt()會(huì)在刪除后更新dataTable的index,所以你要?jiǎng)h除的index可能已經(jīng)不是你的符合Convert.ToInt32(dt.Rows[i]["RowID"]) == RowID的index了,甚者還會(huì)拋出異常,說你訪問的index不存在。

  所以要從DataTable的下面往上查找刪除,這樣即使這行符合條件被刪除了,上面的行依舊不受影響。

        正確的寫法如下:

    protected void deleteDataRow(int RowID,DataTable dt)
    {
        
for (int i = dt.Rows.Count - 1; i >= 0; i--)
        {
            
if (Convert.ToInt32(dt.Rows[i]["RowID"]) == RowID)
                dt.Rows.RemoveAt(i);
        }
    }
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
c#獲取當(dāng)前日期是今年第幾周
Json DataTable
DataTable轉(zhuǎn)換為二維數(shù)組
求出datatable的列名
把兩張DataTable拼接成一張全新的DataTable
SqlDataAdapter.Update批量數(shù)據(jù)更新
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服