C# Table.Rows[index].Delete()

來源:互聯網
上載者:User
如果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()的內容,更多相關內容請關注topic.alibabacloud.com(www.php.cn)!

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.