C# Table.Rows[index].Delete()
如果DataRow.Delete()方法被調用,對應行的RowState屬性就會被設定成DataRowState.Deleted。當一個行的狀態是DataRowState.Deleted的時候,正常情況下我們無法存取這一行。如果你需要檢索已刪除的原始數據,可以使用其條目屬性的重載方法來傳遞DataRowVersion.Original參數。
程式碼像這樣:
if (typedDataRow.RowState == DataRowState.Deleted) id = (string)typedDataRow["CustomerID", DataRowVersion.Original];
採用datatable.Rows[i].Delete()刪除行或在DataGrid上按Del鍵刪除行後再存取該表時出現「無法透過已刪除的行存取該行的資訊」的錯誤。原因如下:
Delete()之後需要datatable.AccepteChanges()方法確認完全刪除,因為Delete()只是將對應列的狀態標誌為刪除,也可以透過datatable.RejectChanges()回滾,使該行取消刪除。
所以如果要徹底刪除datarow,需要Delete()和AccepteChanges()方法同時使用,或者採用datatable.Rows.RemoveAt(i)方法直接刪除,其中i表示行索引,還有一個就是datatable.Rows.Remove(DataRow dr)刪除指定行。
不過使用datatable.Rows.RemoveAt(i)要注意,如果連續使用datatable.Rows.RemoveAt(0);datatable.Rows.RemoveAt(1);這時並不是刪除了原表中的0,1行,而是刪除0行後,原來的1行就變成了0行,所以datatable.Rows.RemoveAt(1)實際刪除的是原表的2行。此時應該 i = i - 1;
所以還是要慎用datatable.Rows.RemoveAt(i)
小註:
行版本(DataRowVersion )
行(DataRow)物件有四種不同的行版本,分別是Current,Original,proposed和default。下面對這些行版本進行簡要的說明。
Current:表示行的目前值。處於deleted狀態的行不存在該行版本。
Original:表示行的原始值。處於Added狀態的行不存在該行版本
Proposed:表示行的建議值。不屬於表格的行,即處於Detached狀態的行存在該行版本;對於正在進行編輯的行,也存在該行版本。
Default:表示行的預設版本。處於Added,Modified或則Unchanged狀態的行的預設行版本是current;處於deleted狀態的行的預設行版本是original。處於Detached狀態的行的預設版本是proposed。
以上是C# Table.Rows[index].Delete()的內容,更多相關內容請關注PHP中文網(www.php.cn)!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

使用 C# 的 Active Directory 指南。在這裡,我們討論 Active Directory 在 C# 中的介紹和工作原理以及語法和範例。

多線程和異步的區別在於,多線程同時執行多個線程,而異步在不阻塞當前線程的情況下執行操作。多線程用於計算密集型任務,而異步用於用戶交互操作。多線程的優勢是提高計算性能,異步的優勢是不阻塞 UI 線程。選擇多線程還是異步取決於任務性質:計算密集型任務使用多線程,與外部資源交互且需要保持 UI 響應的任務使用異步。
