DataTable的AcceptChanges()和RejectChanges()方法介绍并实现DataGridView数据增、删、改

一、DataTable.AcceptChanges()方法

提交自上次调用AcceptChanges()方法以来对该表进行的所有更改。调用AcceptChanges()时,任何扔处于编辑模式的DataRow对象将成功结束其编辑。DataRowState也会随之更改:所有状态为Added何Modified的行的状态都变为Unchanged;状态为Deleted的行则被移除。

在尝试使用DbDataAdapter.Update方法更新DataSet之后,通常会对DataTable调用AcceptChanges方法。

二、DataTable.RejectChanges()方法

回滚自该表加载以来或上次调用AcceptChanges()以来对该表进行的所有更改。调用RejectChanges时,任何扔处于编辑模式的DataRow对象将取消其编辑。新行被移除。DataRowState设置为Modified或Deleted的行返回到其初始状态。

使用Delete()方法后,RowState变成“Deleted”状态。在您调用AcceptChanges之前,它一直保持“Deleted”状态。可通过调用RejectChanges取消删除行。

用于从DataTable对象中删除DataRow对象的方法有两种:DataRowCollection对象的Remove()方法和DataRow对象的Delete()方法。Rwmove()方法从DataRowCollection中删除DataRow,而Delete()方法只是将行的状态标记为删除,当应用程序调用AcceptChanges()方法时,才会发生实际的删除。通过使用Delete()方法,您可以在实际删除之前先以编程的方式检查哪些行标记为删除。

在将 DataSet 或 DataTable 与 DataAdapter 和关系型数据源一起使用时,用 DataRow 的 Delete 方法移除行。Delete 方法只是在 DataSet 或 DataTable 中将行标记为 Deleted,而不会移除它。而 DataAdapter 在遇到标记为 Deleted 的行时,会执行其 DeleteCommand 方法以在数据源中删除该行。然后,就可以用 AcceptChanges 方法永久移除该行。如果使用 Remove 删除该行,则该行将从表中完全移除,但 DataAdapter 不会在数据源中删除该行。

三、项目示例

1、界面设计

2、代码实现

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();
                //填充数据
                adapter.Fill(dsDgv);

                this.dgv_Demo.DataSource = dsDgv.Tables[0];
                //不显示最后的空行
                this.dgv_Demo.AllowUserToAddRows = false;
                // 设置第一列只读
                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();

            //产生与表Users结构相同的空表
            DataTable dtAdd = GetEmptyTable();
            DataTable dtEdit = GetEmptyTable();
            DataTable dtDel = GetEmptyTable();

            //根据DataRowState的状态获取新增、修改、删除的表数据
            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);
            }
            //保存数据
            if (SaveUser(dsUsers))
            {
                MessageBox.Show("保存成功!");
                //重新加载数据
                Initdgv();
            }
            else
            {
                MessageBox.Show("保存失败!");
            }
        }

        /// <summary>
        /// 根据表结构产生空表
        /// </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>
        /// 保存数据
        /// </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>
        /// 数据库增加
        /// </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>
        /// 数据库删除
        /// </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>
        /// 数据库修改
        /// </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>
         /// 数据库执行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中显示的数据,并没有删除数据库中的数据
                    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没有绑定数据时才可以使用Add()方法增加空行
            this.dgv_Demo.Rows.Add();
        }

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

到此这篇关于DataTable的AcceptChanges()和RejectChanges()方法介绍并实现DataGridView数据增、删、改的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C#实现绑定DataGridView与TextBox之间关联的方法

    本文实例讲述了C#实现绑定DataGridView与TextBox之间关联的方法.分享给大家供大家参考.具体实现方法如下: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; namespace System.Window

  • C#实现DataGridView控件行列互换的方法

    本文实例讲述了C#实现DataGridView控件行列互换的方法.分享给大家供大家参考.具体如下: 该示例程序是一个Windows窗体应用程序,有左右两个DataGridView控件:dgvLeft和dgvRight dgvRight除时间外的每一行是dgvLeft的一列 private void Form1_Load(object sender, EventArgs e) { //C#中确定控件DataGridView根据内容自动调整列宽长度的属性 //是AutoSizeColumnsMode

  • C#重写DataGridView

    本文实例为大家分享了C#重写DataGridView的实例代码,供大家参考,具体内容如下 using System; using System.Collections.Generic; using System.Text; using System.Drawing; using System.Windows.Forms; using System.Drawing.Drawing2D; namespace CRD.WinUI.Editors { public class DataGridView

  • C#开发WinForm之DataGridView开发详解

    前言 DataGridView是开发Winform的一个列表展示,类似于表格.学会下面的基本特征用法,再辅以经验,基本功能开发没问题. 基本的数据渲染 根据提供的数据展示出效果. 提供给DataGridView数据源有很多方式,大致有如下三种: 直接增加,每个单元格类型都是DataGridViewTextBoxCell int index=this.dataGridView1.Rows.Add(); this.dataGridView1.Rows[index].Cells[0].Value =

  • C#中datagridview使用tooltip控件显示单元格内容的方法

    本文实例讲述了C#中datagridview使用tooltip控件显示单元格内容的方法.分享给大家供大家参考,具体如下: 代码如下: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms;

  • C#中DataGridView常用操作实例小结

    本文实例讲述了C#中DataGridView常用操作.分享给大家供大家参考.具体如下: public void Binder1() { DataTable tableType = DataBase.SQLDBHelper.GetDataTable("select top 200 unit_code,unit_name from unit "); DataTable table = DataBase.SQLDBHelper.GetDataTable("select top 2

  • C#数据表格(DataGridView)控件的应用案例

    我们通过一个完整的实例来实现课程信息管理功能的操作,包括查询.修改.删除课程信息的操作. 为了简化实例,添加课程信息的操作直接在 SQL Server 数据库中完成. 下面分几个步骤完成. 1) 创建课程信息表创建课程信息表的 SQL 语句如下. use test; create table course ( id int primary key identity(1,1), name varchar(20), credit numeric(3,1), remark varchar(50) );

  • C#自定义DataGridViewColumn显示TreeView

    我们可以自定义DataGridView的DataGridViewColumn来实现自定义的列,下面介绍一下如何通过扩展DataGridViewColumn来实现一个TreeViewColumn 1.TreeViewColumn类 TreeViewColumn继承自DataGridViewColumn,为了动态给TreeViewColumn传入一个TreeView,这里暴露出一个公共属性_root,可以绑定一个初始化的TreeView. 另外需要重写DataGridCell类型的CellTempl

  • C# DataGridView绑定数据源的方法

    开始以前,先认识一下WinForm控件数据绑定的两种形式,简单数据绑定和复杂数据绑定. 1. 简单的数据绑定 例1 using (SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["connStr"].ToString())) { SqlDataAdapter sda = new SqlDataAdapter("Select * From T_Class Where F_

  • C#窗体控件DataGridView常用设置

    在默认情况下,datagridview的显示效果: 1.禁用最后一行空白. 默认情况下,最后一行空白表示自动新增行,对于需要在控件中进行编辑,可以保留 dataGridView1.AllowUserToAddRows = false; 上述禁用,仅是将用户界面交互的自动新增行禁了,但还是可以通过代码:dataGridView1.Rows.Add();来新增一行空白. 2.禁用'delete'键的删除功能. 默认情况,鼠标选中一整行,按 删除键 可以删除当前一整行 dataGridView1.Al

  • C# 实现dataGridView选中一行右键出现菜单的示例代码

    在窗体中添加DataGridView控件和ConTextMenuStrip1控件,修改DataGridView属性,将contextMenuStrip控件绑定dataGridView控件 this.dataGridView1.SelectionMode = DataGridViewSelectionMode.FullRowSelect; //选中整行可在属性中修改 datagridview.AutoGenerateColumns = false;//不让datagridview自动生成列,可在属

  • C#中DataGridView动态添加行及添加列的方法

    本文实例讲述了C#中DataGridView动态添加行及添加列的方法.分享给大家供大家参考.具体如下: Datagridview添加列: DataGridViewTextBoxColumn acCode = new DataGridViewTextBoxColumn(); acCode.Name = "acCode"; acCode.DataPropertyName = "acCode"; acCode.HeaderText = "A/C Code&quo

  • C#实现3步手动建DataGridView的方法

    本文实例讲述了C#实现3步手动建DataGridView的方法.分享给大家供大家参考.具体如下: DataView dvCmControlInfo =  new  DataView(某个DataTable); 第一步 dataGridView1.Columns.Clear(); dataGridView1.AutoGenerateColumns = false ; dataGridView1.DataSource = dvCmControlInfo; //绑DataTable,DataSet,D

随机推荐