中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C#如何獲取DataTable對象狀態DataRowState

發布時間:2022-02-28 09:27:22 來源:億速云 閱讀:131 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關C#如何獲取DataTable對象狀態DataRowState,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

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();
        }

        /// <summary>
        /// 創建一個空的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;
        }
    }
}

關于“C#如何獲取DataTable對象狀態DataRowState”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兰溪市| 交城县| 嘉祥县| 峨山| 大厂| 西平县| 辽中县| 青川县| 岱山县| 安阳县| 加查县| 嘉兴市| 洛隆县| 若羌县| 南开区| 旌德县| 平顶山市| 昭苏县| 绥化市| 闽侯县| 广丰县| 仁怀市| 聂荣县| 雷波县| 德庆县| 东明县| 太仓市| 顺平县| 观塘区| 雅江县| 萍乡市| 耿马| 攀枝花市| 伊川县| 饶阳县| 新野县| 米脂县| 上杭县| 澄迈县| 缙云县| 衡阳市|