欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#獲取DataTable對(duì)象狀態(tài)DataRowState

 更新時(shí)間:2022年02月26日 10:00:42   作者:.NET開發(fā)菜鳥  
這篇文章介紹了C#獲取DataTable對(duì)象狀態(tài)DataRowState的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

DataGridView:獲取 DataRow 對(duì)象的狀態(tài),共有5個(gè)枚舉值。

Added該行已添加到 DataRowCollection 中,AcceptChanges 尚未調(diào)用。
Deleted該行已通過 DataRow 的 Delete 方法被刪除。 
Detached該行已被創(chuàng)建,但不屬于任何 DataRowCollection。DataRow 在以下情況下立即處于此狀態(tài):創(chuàng)建之后添加到集合中之前;或從集合中移除之后。 
Modified該行已被修改,AcceptChanges 尚未調(diào)用。 
Unchanged該行自上次調(diào)用 AcceptChanges 以來尚未更改。 

一個(gè)DataRow對(duì)象剛被創(chuàng)建之后其狀態(tài)是Detached,是孤立的一個(gè)存在,所以建立了DataRow之后在通過DataTable.Rows.Add(DataRow)方法將此DataRow添加到DataTable,這時(shí),DataRow的狀態(tài)由Detached轉(zhuǎn)變?yōu)锳dded。

當(dāng)修改了這個(gè)DataRow后,這個(gè)DataRow的狀態(tài)轉(zhuǎn)變?yōu)镸odified,當(dāng)用DataRow.Delete()方法刪除DataRow后,DataRow狀態(tài)將轉(zhuǎn)變?yōu)镈eleted,不過此行還存在在DataTable中,只是狀態(tài)改變了,這時(shí)用DataTable.Rows.Count查看行數(shù),跟刪除前是一樣的。

在使用Delete方法后,RowState變成“Deleted”。在您調(diào)用AcceptChanges之前,它一直保持“已刪除”,這時(shí)不能再修改該行,否則會(huì)報(bào)錯(cuò):不能通過已刪除的行訪問該行的信息??梢允褂肦ejectChanges取消刪除行。

Deleted狀態(tài)下,如果還想重新使用該行,可以在調(diào)用AcceptChanges后,重新使用DataTable.Rows.Add(DataRow)方法加入,這時(shí)行的狀態(tài)轉(zhuǎn)變?yōu)锳dded。

注意:

  • 1、只有在Added狀態(tài)下使用Delete(),該行才能在DataTable中刪除,使Rows.Count-1,DataRow的狀態(tài)變?yōu)镈etached(游離狀態(tài),使用NewRow()實(shí)例化行,還沒加入到DataTable中也是這種狀態(tài))。如果在Added狀態(tài)下使用DataTable.AcceptChanges()方法之后,在使用DataRow.Delete()方法,該行不會(huì)從DataTable中刪除,只是把狀態(tài)變?yōu)镈eleted,行數(shù)不變。
  • 2、Unchange(非Deleted行在調(diào)用AcceptChanges后的狀態(tài),直接從數(shù)據(jù)庫中取的也是這種狀態(tài)),在修改內(nèi)容或調(diào)用Delete()后,變?yōu)镸odify或者Deleted狀態(tài)
  • 3、Added在修改后還是Added
  • 4、Unchange和Modify狀態(tài)下調(diào)用Delete()會(huì)轉(zhuǎn)變以Deleted,但Rows.Count并不減少
  • 5、Deleted狀態(tài)下如果修改該行內(nèi)容會(huì)報(bào): 不能通過已刪除的行訪問該行的信息 錯(cuò)誤
  • 6、Deleted狀態(tài)下,如果還想重新使用該行,可以在調(diào)用AcceptChanges 后,重新使用 Table.Rows.Add(DataRow)方法加入,加入后的狀態(tài)為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)
        {
            //創(chuàng)建一個(gè)DataTable
            DataTable dtDemo = GetDataTable();
            DataRow myDr;

            //Detached row:該行已經(jīng)被創(chuàng)建,但不屬于任何DataRowCollection
            myDr = dtDemo.NewRow();
            Console.WriteLine("New Row狀態(tài):"+myDr.RowState);
            //將新創(chuàng)建的行添加到DataTable中
            dtDemo.Rows.Add(myDr);
            Console.WriteLine("Add Row狀態(tài):"+myDr.RowState);

            #region Add之后直接使用Delete,RowState變?yōu)镈etached,  行數(shù)-1
            //myDr.Delete();
            //Console.WriteLine("myDr的狀態(tài):" + myDr.RowState);
            //Console.WriteLine("dtDemo的行數(shù):" + dtDemo.Rows.Count.ToString());
            #endregion

            dtDemo.AcceptChanges();
            Console.WriteLine("AcceptChanges狀態(tài):" + myDr.RowState);
            //修改
            myDr["Name"] = "Tom";
            Console.WriteLine("Modified狀態(tài):" + myDr.RowState);
            Console.WriteLine("刪除前的行數(shù):" + dtDemo.Rows.Count.ToString());

            #region 非Added狀態(tài)下使用Delete,RowState變?yōu)镈eleted,  行數(shù)不變
            myDr.Delete();
            Console.WriteLine("Deleted狀態(tài):" + myDr.RowState);
            Console.WriteLine("刪除后的行數(shù):" + dtDemo.Rows.Count.ToString());
            #endregion

            //這時(shí)myDr的狀態(tài)變?yōu)镈etached
            Console.WriteLine("myDr的狀態(tài):" + myDr.RowState);
            //重新加入myDr,這時(shí)狀態(tài)變?yōu)锳dded
            dtDemo.Rows.Add(myDr);
            Console.WriteLine("myDr的狀態(tài):" + myDr.RowState);
            //取消刪除行
            //dtDemo.RejectChanges();
            Console.ReadKey();
        }

        /// <summary>
        /// 創(chuàng)建一個(gè)空的DataTable
        /// </summary>
        /// <returns></returns>
        static DataTable GetDataTable()
        {
            DataTable dt = new DataTable("MyTable");
            DataColumn dc = new DataColumn("Name", typeof(string));
            dt.Columns.Add(dc);
            return dt;
        }
    }
}

到此這篇關(guān)于C#獲取DataTable對(duì)象狀態(tài)DataRowState的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C#實(shí)現(xiàn)用戶自定義控件中嵌入自己的圖標(biāo)

    C#實(shí)現(xiàn)用戶自定義控件中嵌入自己的圖標(biāo)

    這篇文章主要介紹了C#實(shí)現(xiàn)用戶自定義控件中嵌入自己的圖標(biāo),較為詳細(xì)的分析了C#實(shí)現(xiàn)自定義控件中嵌入圖標(biāo)的具體步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2016-03-03
  • 如何用C#實(shí)現(xiàn)壓縮文件

    如何用C#實(shí)現(xiàn)壓縮文件

    話說當(dāng)今壓縮市場(chǎng)三足鼎立,能叫上名號(hào)的有zip、rar、7z。其中zip是壓縮界的鼻祖,在各大平臺(tái)上的流行度最廣,rar是商業(yè)軟件,壓縮率和效率都是很高的。7z是開源的,屬于后起之秀。這篇文章介紹了如何使用ICSharpCode組件,在windows平臺(tái)下zip的壓縮與解壓的方法
    2021-06-06
  • C#排序算法之歸并排序

    C#排序算法之歸并排序

    這篇文章主要為大家詳細(xì)介紹了C#排序算法之歸并排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • WCF分布式開發(fā)之MSMQ消息隊(duì)列

    WCF分布式開發(fā)之MSMQ消息隊(duì)列

    這篇文章介紹了WCF分布式開發(fā)之MSMQ消息隊(duì)列,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • C#判斷字符串中內(nèi)容是否為純數(shù)字的詳細(xì)教程

    C#判斷字符串中內(nèi)容是否為純數(shù)字的詳細(xì)教程

    在進(jìn)行C#編程時(shí)候,有的時(shí)候我們需要判斷一個(gè)字符串是否是數(shù)字字符串,下面這篇文章主要給大家介紹了關(guān)于C#判斷字符串中內(nèi)容是否為純數(shù)字的詳細(xì)教程,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • 那些年,我還在學(xué)習(xí)C# 學(xué)習(xí)筆記續(xù)

    那些年,我還在學(xué)習(xí)C# 學(xué)習(xí)筆記續(xù)

    那些年學(xué)習(xí)C#,就是對(duì)C#相關(guān)的一些知識(shí)有一個(gè)了解,等到要用時(shí)才不會(huì)找不到方向,比如說擴(kuò)展方法,開始時(shí)怎么覺得沒有用,后來了解到asp.net MVC,它可以用來擴(kuò)展Html類,比如做一個(gè)分頁的方法;所以對(duì)一門語言了解寬一些是沒有壞處的
    2012-03-03
  • Unity3D實(shí)現(xiàn)分頁系統(tǒng)

    Unity3D實(shí)現(xiàn)分頁系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了Unity3D實(shí)現(xiàn)分頁系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C#使用JArray和JObject封裝JSON對(duì)象

    C#使用JArray和JObject封裝JSON對(duì)象

    這篇文章介紹了C#使用JArray和JObject封裝JSON對(duì)象的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • C#通過XML節(jié)點(diǎn)屬性/屬性值讀取寫入XML操作代碼實(shí)例

    C#通過XML節(jié)點(diǎn)屬性/屬性值讀取寫入XML操作代碼實(shí)例

    本文主要介紹C#通過XML節(jié)點(diǎn)屬性、屬性值對(duì)XML的讀取,寫入操作,大家參考使用吧
    2013-11-11
  • Unity 從Resources中動(dòng)態(tài)加載Sprite圖片的操作

    Unity 從Resources中動(dòng)態(tài)加載Sprite圖片的操作

    這篇文章主要介紹了Unity 從Resources中動(dòng)態(tài)加載Sprite圖片的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04

最新評(píng)論