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。
最後更新:2017-04-03 20:19:22
上一篇:
ORACLE 官方文檔
下一篇:
C# WinForm中PreviewKeyDown、KeyDown、KeyPress、KeyUp區別與聯係
《數據驅動安全:數據安全分析、可視化和儀表盤》一1.3.1 創建一個好的研究問題
幣幣交易係統網站搭建,幣幣交易係統開發
阿裏研究院啟動2017年度淘寶村輔助認證活動(附表格下載)
ZPush--基於netty4實現的蘋果通知推送服務(APNs)Java客戶端
電商:功能遍曆場景
《vSphere性能設計:性能密集場景下CPU、內存、存儲及網絡的最佳設計實踐》一2.2 性能分析工具
DIY圖像壓縮——機器學習實戰之K-means 聚類圖像壓縮:色彩量化
三層加抽象工廠加反射加配置文件加SqlHelper
HTAP數據庫 PostgreSQL 場景與性能測試之 15 - (OLTP) 物聯網 - 查詢一個時序區間的數據
不寫代碼也可以駕馭阿裏雲OpenAPI