網站首頁 編程語言 正文
DataGridView:獲取?DataRow?對象的狀態,共有5個枚舉值。
Added | 該行已添加到?DataRowCollection?中,AcceptChanges?尚未調用。 |
Deleted | 該行已通過?DataRow?的?Delete?方法被刪除。? |
Detached | 該行已被創建,但不屬于任何?DataRowCollection。DataRow?在以下情況下立即處于此狀態:創建之后添加到集合中之前;或從集合中移除之后。? |
Modified | 該行已被修改,AcceptChanges?尚未調用。? |
Unchanged | 該行自上次調用?AcceptChanges?以來尚未更改。? |
一個DataRow對象剛被創建之后其狀態是Detached,是孤立的一個存在,所以建立了DataRow之后在通過DataTable.Rows.Add(DataRow)方法將此DataRow添加到DataTable,這時,DataRow的狀態由Detached轉變為Added。
當修改了這個DataRow后,這個DataRow的狀態轉變為Modified,當用DataRow.Delete()方法刪除DataRow后,DataRow狀態將轉變為Deleted,不過此行還存在在DataTable中,只是狀態改變了,這時用DataTable.Rows.Count查看行數,跟刪除前是一樣的。
在使用Delete方法后,RowState變成“Deleted”。在您調用AcceptChanges之前,它一直保持“已刪除”,這時不能再修改該行,否則會報錯:不能通過已刪除的行訪問該行的信息。可以使用RejectChanges取消刪除行。
Deleted狀態下,如果還想重新使用該行,可以在調用AcceptChanges后,重新使用DataTable.Rows.Add(DataRow)方法加入,這時行的狀態轉變為Added。
注意:
- 1、只有在Added狀態下使用Delete(),該行才能在DataTable中刪除,使Rows.Count-1,DataRow的狀態變為Detached(游離狀態,使用NewRow()實例化行,還沒加入到DataTable中也是這種狀態)。如果在Added狀態下使用DataTable.AcceptChanges()方法之后,在使用DataRow.Delete()方法,該行不會從DataTable中刪除,只是把狀態變為Deleted,行數不變。
- 2、Unchange(非Deleted行在調用AcceptChanges后的狀態,直接從數據庫中取的也是這種狀態),在修改內容或調用Delete()后,變為Modify或者Deleted狀態
- 3、Added在修改后還是Added
- 4、Unchange和Modify狀態下調用Delete()會轉變以Deleted,但Rows.Count并不減少
- 5、Deleted狀態下如果修改該行內容會報:?不能通過已刪除的行訪問該行的信息 錯誤
- 6、Deleted狀態下,如果還想重新使用該行,可以在調用AcceptChanges 后,重新使用 Table.Rows.Add(DataRow)方法加入,加入后的狀態為Added。
示例代碼:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Data; namespace ConsoleApplication1 { class Program { static void Main(string[] args) { //創建一個DataTable DataTable dtDemo = GetDataTable(); DataRow myDr; //Detached row:該行已經被創建,但不屬于任何DataRowCollection myDr = dtDemo.NewRow(); Console.WriteLine("New Row狀態:"+myDr.RowState); //將新創建的行添加到DataTable中 dtDemo.Rows.Add(myDr); Console.WriteLine("Add Row狀態:"+myDr.RowState); #region Add之后直接使用Delete,RowState變為Detached, 行數-1 //myDr.Delete(); //Console.WriteLine("myDr的狀態:" + myDr.RowState); //Console.WriteLine("dtDemo的行數:" + dtDemo.Rows.Count.ToString()); #endregion dtDemo.AcceptChanges(); Console.WriteLine("AcceptChanges狀態:" + myDr.RowState); //修改 myDr["Name"] = "Tom"; Console.WriteLine("Modified狀態:" + myDr.RowState); Console.WriteLine("刪除前的行數:" + dtDemo.Rows.Count.ToString()); #region 非Added狀態下使用Delete,RowState變為Deleted, 行數不變 myDr.Delete(); Console.WriteLine("Deleted狀態:" + myDr.RowState); Console.WriteLine("刪除后的行數:" + dtDemo.Rows.Count.ToString()); #endregion //這時myDr的狀態變為Detached Console.WriteLine("myDr的狀態:" + myDr.RowState); //重新加入myDr,這時狀態變為Added dtDemo.Rows.Add(myDr); Console.WriteLine("myDr的狀態:" + myDr.RowState); //取消刪除行 //dtDemo.RejectChanges(); Console.ReadKey(); } ////// 創建一個空的DataTable /// ///static DataTable GetDataTable() { DataTable dt = new DataTable("MyTable"); DataColumn dc = new DataColumn("Name", typeof(string)); dt.Columns.Add(dc); return dt; } } }
原文鏈接:https://www.cnblogs.com/dotnet261010/p/6681109.html
相關推薦
- 2023-01-02 使用Flutter?構建Web應用邏輯解析_Android
- 2022-10-03 github訪問速度慢的問題完美解決_相關技巧
- 2022-10-04 Android系統優化Ninja加快編譯_Android
- 2022-08-19 一篇文章讓你看懂用git上傳文件至gitee,結尾有.gitignore配置
- 2022-08-01 MongoDB基礎之查詢文檔_MongoDB
- 2022-07-09 設置滾動條默認樣式 谷歌瀏覽器
- 2022-06-23 muduo源碼分析之TcpServer模塊詳細介紹_Redis
- 2022-02-20 Ubuntu18.04更改apt源為阿里云源的詳細過程_Linux
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支