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

DataTable的AcceptChanges()和RejectChanges()方法介紹并實現(xiàn)DataGridView數(shù)據(jù)增、刪、改

 更新時間:2022年02月26日 10:10:29   作者:.NET開發(fā)菜鳥  
這篇文章介紹了DataTable的AcceptChanges()和RejectChanges()方法并實現(xiàn)DataGridView數(shù)據(jù)增、刪、改,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

一、DataTable.AcceptChanges()方法

提交自上次調(diào)用AcceptChanges()方法以來對該表進行的所有更改。調(diào)用AcceptChanges()時,任何扔處于編輯模式的DataRow對象將成功結(jié)束其編輯。DataRowState也會隨之更改:所有狀態(tài)為Added何Modified的行的狀態(tài)都變?yōu)閁nchanged;狀態(tài)為Deleted的行則被移除。

在嘗試使用DbDataAdapter.Update方法更新DataSet之后,通常會對DataTable調(diào)用AcceptChanges方法。

二、DataTable.RejectChanges()方法

回滾自該表加載以來或上次調(diào)用AcceptChanges()以來對該表進行的所有更改。調(diào)用RejectChanges時,任何扔處于編輯模式的DataRow對象將取消其編輯。新行被移除。DataRowState設(shè)置為Modified或Deleted的行返回到其初始狀態(tài)。

使用Delete()方法后,RowState變成“Deleted”狀態(tài)。在您調(diào)用AcceptChanges之前,它一直保持“Deleted”狀態(tài)??赏ㄟ^調(diào)用RejectChanges取消刪除行。

用于從DataTable對象中刪除DataRow對象的方法有兩種:DataRowCollection對象的Remove()方法和DataRow對象的Delete()方法。Rwmove()方法從DataRowCollection中刪除DataRow,而Delete()方法只是將行的狀態(tài)標記為刪除,當應用程序調(diào)用AcceptChanges()方法時,才會發(fā)生實際的刪除。通過使用Delete()方法,您可以在實際刪除之前先以編程的方式檢查哪些行標記為刪除。

在將 DataSet 或 DataTable 與 DataAdapter 和關(guān)系型數(shù)據(jù)源一起使用時,用 DataRow 的 Delete 方法移除行。Delete 方法只是在 DataSet 或 DataTable 中將行標記為 Deleted,而不會移除它。而 DataAdapter 在遇到標記為 Deleted 的行時,會執(zhí)行其 DeleteCommand 方法以在數(shù)據(jù)源中刪除該行。然后,就可以用 AcceptChanges 方法永久移除該行。如果使用 Remove 刪除該行,則該行將從表中完全移除,但 DataAdapter 不會在數(shù)據(jù)源中刪除該行。

三、項目示例

1、界面設(shè)計

2、代碼實現(xiàn)

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;

namespace DataRowStateDemo
{
    public partial class FrmMain : Form
    {
        public FrmMain()
        {
            InitializeComponent();
        }

        //連接字符串
        string strConn = ConfigurationManager.ConnectionStrings["DbConn"].ConnectionString;

        /// <summary>
        /// 加載
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btn_LoadData_Click(object sender, EventArgs e)
        {
            Initdgv();
            this.btn_Add.Visible = false;
        }

        /// <summary>
        /// 初始化DataGridView
        /// </summary>
        private void Initdgv()
        {
            SqlConnection conn = new SqlConnection(strConn);
            string strSQL = "select * from Users";
            SqlCommand cmd = new SqlCommand(strSQL, conn);
            SqlDataAdapter adapter = new SqlDataAdapter(cmd);
            DataSet dsDgv = new System.Data.DataSet();
            try
            {
                conn.Open();
                //填充數(shù)據(jù)
                adapter.Fill(dsDgv);

                this.dgv_Demo.DataSource = dsDgv.Tables[0];
                //不顯示最后的空行
                this.dgv_Demo.AllowUserToAddRows = false;
                // 設(shè)置第一列只讀
                this.dgv_Demo.Columns[0].ReadOnly = true;
            }
            catch (Exception ex)
            { }
            finally
            {
                conn.Close();
            }
        }

        /// <summary>
        /// 編輯
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btn_Edit_Click(object sender, EventArgs e)
        {
            this.dgv_Demo.AllowUserToAddRows = true;
        }

        /// <summary>
        /// 保存
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btn_Save_Click(object sender, EventArgs e)
        {
            DataTable dtCopy = this.dgv_Demo.DataSource as DataTable;
            DataSet dsUsers = new DataSet();

            //產(chǎn)生與表Users結(jié)構(gòu)相同的空表
            DataTable dtAdd = GetEmptyTable();
            DataTable dtEdit = GetEmptyTable();
            DataTable dtDel = GetEmptyTable();

            //根據(jù)DataRowState的狀態(tài)獲取新增、修改、刪除的表數(shù)據(jù)
            dtAdd = dtCopy.GetChanges(DataRowState.Added);
            dtEdit = dtCopy.GetChanges(DataRowState.Modified);
            dtDel = dtCopy.GetChanges(DataRowState.Deleted);

            //新增
            if (dtAdd != null)
            {
                dtAdd.TableName = "Added";
                dsUsers.Tables.Add(dtAdd);
            }
            //修改
            if (dtEdit != null)
            {
                dtEdit.TableName = "Edit";
                dsUsers.Tables.Add(dtEdit);
            }
            //刪除
            if (dtDel != null)
            {
                dtDel.TableName = "Del";
                dtDel.RejectChanges();
                dsUsers.Tables.Add(dtDel);
            }
            //保存數(shù)據(jù)
            if (SaveUser(dsUsers))
            {
                MessageBox.Show("保存成功!");
                //重新加載數(shù)據(jù)
                Initdgv();
            }
            else
            {
                MessageBox.Show("保存失敗!");
            }
        }

        /// <summary>
        /// 根據(jù)表結(jié)構(gòu)產(chǎn)生空表
        /// </summary>
        /// <returns></returns>
        private DataTable GetEmptyTable()
        {
            DataTable dtTable = new DataTable("Users");
            //使用集合初始化器添加列
            dtTable.Columns.AddRange(new DataColumn[]{
                   new DataColumn("UserID",typeof(Int32)),
                   new DataColumn("UserName",typeof(string)),
                   new DataColumn("Password",typeof(string)),
                   new DataColumn("Sex",typeof(Char)),
                   new DataColumn("Birthday",typeof(DateTime))
            });
            return dtTable;
        }

        /// <summary>
        /// 保存數(shù)據(jù)
        /// </summary>
        /// <param name="ds"></param>
        /// <returns></returns>
        private bool SaveUser(DataSet ds)
        {
            bool tf = false;
            //新增
            if (ds.Tables["Added"] != null)
            {
                foreach (DataRow dr in ds.Tables["Added"].Rows)
                {
                   tf= InsertUser(dr);
                }
            }
            //修改
            if (ds.Tables["Edit"] != null)
            {
                foreach (DataRow dr in ds.Tables["Edit"].Rows)
                {
                    tf = UpdateUser(dr);
                }
            }
            //刪除
            if (ds.Tables["Del"] != null)
            {
                foreach (DataRow dr in ds.Tables["Del"].Rows)
                {
                    tf = DeleteUser(dr);
                }
            }
            return tf;
        }

        /// <summary>
        /// 數(shù)據(jù)庫增加
        /// </summary>
        /// <param name="drDataRow"></param>
        /// <returns></returns>
        private bool InsertUser(DataRow drDataRow)
        {
            string strSQL = string.Format(@"insert into users values('{0}','{1}','{2}','{3}')", drDataRow["UserName"].ToString(), drDataRow["Password"].ToString(),                                                 drDataRow["Sex"].ToString(), drDataRow["Birthday"].ToString());
            return ExecuteSQL(strSQL);
        }

        /// <summary>
        /// 數(shù)據(jù)庫刪除
        /// </summary>
        /// <param name="drDataRow"></param>
        /// <returns></returns>
        private bool DeleteUser(DataRow drDataRow)
        {
            string strSQL = string.Format("delete from users where UserID='{0}'", Convert.ToInt32(drDataRow["UserID"].ToString()));
            return ExecuteSQL(strSQL);
        }

        /// <summary>
        /// 數(shù)據(jù)庫修改
        /// </summary>
        /// <param name="drDataRow"></param>
        /// <returns></returns>
        private bool UpdateUser(DataRow drDataRow)
        {
            string strSQL = string.Format("update users set UserName='{0}',Password='{1}',Sex='{2}',Birthday='{3}' where UserID='{4}'",
                                         drDataRow["UserName"].ToString(), drDataRow["Password"].ToString(), drDataRow["Sex"].ToString(),
                                         drDataRow["Birthday"].ToString(), Convert.ToInt32(drDataRow["UserID"].ToString()));
            return ExecuteSQL(strSQL);
        }

         /// <summary>
         /// 數(shù)據(jù)庫執(zhí)行SQL語句
         /// </summary>
         /// <param name="strSQL"></param>
         /// <returns></returns>
        private bool ExecuteSQL(string strSQL)
        {
            bool tfResult = false;
            SqlConnection conn = new SqlConnection(strConn);
            SqlCommand cmd = new SqlCommand(strSQL, conn);
            try
            {
                conn.Open();
                tfResult= cmd.ExecuteNonQuery().Equals(1);
            }
            catch (Exception ex)
            { }
            finally
            {
                conn.Close();
            }

            return tfResult;
        }

        /// <summary>
        /// 刪除
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btn_Del_Click(object sender, EventArgs e)
        {
            if (this.dgv_Demo.SelectedRows.Count <= 0)
            {
                MessageBox.Show("請先選擇要刪除的行");
            }
            else
            {
                foreach(DataGridViewRow dr in this.dgv_Demo.SelectedRows)
                {
                    //只是刪除DataGridView中顯示的數(shù)據(jù),并沒有刪除數(shù)據(jù)庫中的數(shù)據(jù)
                    this.dgv_Demo.Rows.Remove(dr);
                }

            }
        }

        /// <summary>
        /// 增加空行
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btn_Add_Click(object sender, EventArgs e)
        {
            //DataGridView沒有綁定數(shù)據(jù)時才可以使用Add()方法增加空行
            this.dgv_Demo.Rows.Add();
        }

        private void FrmMain_Load(object sender, EventArgs e)
        {
            this.dgv_Demo.AllowUserToAddRows = false;
        }
    }
}

到此這篇關(guān)于DataTable的AcceptChanges()和RejectChanges()方法介紹并實現(xiàn)DataGridView數(shù)據(jù)增、刪、改的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C#中尾遞歸的使用、優(yōu)化及編譯器優(yōu)化

    C#中尾遞歸的使用、優(yōu)化及編譯器優(yōu)化

    這篇文章主要介紹了C#中尾遞歸的使用、優(yōu)化及編譯器優(yōu)化,本文講解了遞歸運用、尾遞歸優(yōu)化、編譯器優(yōu)化等內(nèi)容,需要的朋友可以參考下
    2015-04-04
  • 關(guān)于C#數(shù)強轉(zhuǎn)會不會拋出異常詳解

    關(guān)于C#數(shù)強轉(zhuǎn)會不會拋出異常詳解

    這篇文章主要給大家介紹了關(guān)于C#數(shù)強轉(zhuǎn)會不會拋出異常的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2018-04-04
  • C#實現(xiàn)老板鍵功能的代碼

    C#實現(xiàn)老板鍵功能的代碼

    最近在做項目中遇到需要增加個老板鍵功能,找一慣的方式,開始從網(wǎng)絡下手尋找: 關(guān)鍵字類似”C# 老板鍵“,一搜,一堆又一堆,然而出來的代碼大多數(shù)都不是太合適,下面給大家分享下自己的解決方案已經(jīng)一個網(wǎng)友的解決方案,有需要的小伙伴可以參考下。
    2015-05-05
  • 基于C#實現(xiàn)自定義計算的Excel數(shù)據(jù)透視表

    基于C#實現(xiàn)自定義計算的Excel數(shù)據(jù)透視表

    數(shù)據(jù)透視表(Pivot?Table)是一種數(shù)據(jù)分析工具,通常用于對大量數(shù)據(jù)進行匯總、分析和展示,本文主要介紹了C#實現(xiàn)自定義計算的Excel數(shù)據(jù)透視表的相關(guān)知識,感興趣的可以了解下
    2023-12-12
  • C#獲取文件夾所占空間大小的功能

    C#獲取文件夾所占空間大小的功能

    這篇文章介紹了C#獲取文件夾所占空間大小的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • C#目錄和文件管理操作詳解

    C#目錄和文件管理操作詳解

    在C#中常用的目錄操作類有Directory,DirectoryInfo,下面這篇文章主要給大家介紹了關(guān)于C#目錄和文件管理操作的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • c# 給button添加不規(guī)則的圖片以及用pictureBox替代button響應點擊事件的方法

    c# 給button添加不規(guī)則的圖片以及用pictureBox替代button響應點擊事件的方法

    這篇文章介紹了c# 給button添加不規(guī)則的圖片以及用pictureBox替代button響應點擊事件的方法,有需要的朋友可以參考一下
    2013-09-09
  • C#中Dictionary的作用及用法講解

    C#中Dictionary的作用及用法講解

    這篇文章主要介紹了C#中Dictionary的作用及用法講解,本文還對dictionary類用什么接口實現(xiàn)、Dictionary的基本用法做了講解,需要的朋友可以參考下
    2014-10-10
  • WinForm實現(xiàn)讀取Resource中文件的方法

    WinForm實現(xiàn)讀取Resource中文件的方法

    這篇文章主要介紹了WinForm實現(xiàn)讀取Resource中文件的方法,很實用的一個功能,需要的朋友可以參考下
    2014-08-08
  • c# 實現(xiàn)雪花分形的示例

    c# 實現(xiàn)雪花分形的示例

    這篇文章主要介紹了c# 實現(xiàn)雪花分形的示例,幫助大家更好的利用c#繪制圖像,感興趣的朋友可以了解下
    2020-10-10

最新評論