下面的示例中,通过一个程序,演示使用DataRowState、AcceptChanges、RejectChanges,实现DataGridView数据的增、删、改。

一、界面设计

二、代码实现

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

DataRowState、AcceptChanges、RejectChanges综合使用示例:实现DataGridView数据的增、删、改的更多相关文章

  1. Android SQLite(1)简单示例-增,删,改,查

    1.主要核心类,Sqlite编程要继承SQLiteOpenHelper import android.content.Context; import android.database.sqlite.S ...

  2. 全互联结构DVPN综合配置示例

    以下内容摘自正在全面热销的最新网络设备图书“豪华四件套”之一<H3C路由器配置与管理完全手册>(第二版)(其余三本分别是:<Cisco交换机配置与管理完全手册>(第二版).&l ...

  3. PIE SDK组件式开发综合运用示例

    1. 功能概述 关于PIE SDK的功能开发,在我们的博客上已经分门别类的进行了展示,点击PIESat博客就可以访问,为了初学者入门,本章节将对从PIE SDK组件式二次开发如何搭建界面.如何综合开发 ...

  4. WebRTC VideoEngine综合应用示例(一)——视频通话的基本流程(转)

    本系列目前共三篇文章,后续还会更新 WebRTC VideoEngine综合应用示例(一)——视频通话的基本流程 WebRTC VideoEngine综合应用示例(二)——集成OPENH264编解码器 ...

  5. Django笔记&教程 5-3 综合使用示例

    Django 自学笔记兼学习教程第5章第3节--综合使用示例 点击查看教程总目录 1 - 生成学号场景 场景描述: 教务管理系统中,学生注册账号,学生选择年级后,生成唯一学号. 细节分析: 学生学号由 ...

  6. 学习笔记 DataGridView数据导出为Excel

    DataGridView数据导出为Excel   怎样把WinForm下的“DGV”里的绑定数据库后的数据导出到Excel中. 比如:在窗体里有个一“DGV”,DataGridView1,绑定了数据源 ...

  7. 使用DataGridView数据窗口控件,构建用户快速输入体验

    在"随风飘散" 博客里面,介绍了一个不错的DataGridView数据窗口控件<DataGridView数据窗口控件开发方法及其源码提供下载>,这种控件在有些场合下,还 ...

  8. 多线程更新已排序的Datagridview数据,造成数据错位

    多线程更新已排序的Datagridview数据,触发Datagridview的auto-sort时间,数据重新排序,造成后面更新数据的更新错误. 解决方法: 方法一.设置Datagridview的表头 ...

  9. 第二十节,基本数据类型,集合set、综合应用新数据更新老数据

    基本数据类型,集合set.综合应用新数据更新老数据 创建两个字典新数据,更新原始数据,a为原始数据,b为新数据 1,分别获取到a字典和b字典的key(键),将两个字典的键分别转换成两个集合 2,找出a ...

随机推荐

  1. 如何判断Android手机当前是否联网?

    如果拟开发一个网络应用的程序,首先考虑是否接入网络,在Android手机中判断是否联网可以通过 ConnectivityManager 类的isAvailable()方法判断, 首先获取网络通讯类的实 ...

  2. wap站、手机APP 接入支付宝、微信、银联支付。

    一.wap站 ①.支付宝接入 1.开发前准备:申请一个通过实名认证的企业支付宝账号,并申请开通手机WAP支付功能. 2.流程 参数准备: 企业支付宝账号的PID(也叫ParnerID)和KEY,如果使 ...

  3. C#代码规范 程序员必备的秘笈

    1.引言 本文是一套面向C# programmer和C# developer进行开发所应遵循的开发规范 按照此规范来开发C#程序可带来以下益处: 代码的编写保持一致性,提高代码的可读性和可维护性,在团 ...

  4. Android:GridView中实现点击Item变色,再点击还原。

    使用GridView时想实现点击其中的一个Item,该Item改变背景,再次点击Item变回原来的背景,网上搜了很多资料都没有看到类似的案例,但还是有所启发,现来分享我的做法. 首先,首先为GridV ...

  5. AOE网与关键路径简介

    前面我们说过的拓扑排序主要是为解决一个工程能否顺序进行的问题,但有时我们还需要解决工程完成需要的最短时间问题.如果我们要对一个流程图获得最短时间,就必须要分析它们的拓扑关系,并且找到当中最关键的流程, ...

  6. DCDC纹波小实验

    关于使用示波器測试纹波的注意事项 使用示波器的AC耦合方式測量 因为示波器的头套easy引人噪声,因此在測试前必需把探头的头套去掉 因为电源的高频噪声非常easy通过小电感就能够滤掉,因此更关心的是中 ...

  7. Aixs2 使用总结,持续更新中 ...

    参考博客:http://zhangjunhd.blog.51cto.com/113473/23692     消息交换模式. 目前Axis2支持三种模式:In-Only.Robust-In和In-Ou ...

  8. spineRunTime for cocos2dx v3 中动画播完删除animation

    spineRunTime for cocos2dx v3 中删除animation,发现下面写法会崩溃:   spine::SkeletonAnimation* animationNode = spi ...

  9. MYSQL 更改数据库data存储目录 创建用户 创建权限 设置远程访问的权限.

    一. 怎么更改数据库data存储目录:  1. 安装MYSQL. 2. 切换到 C:\Program Files\MySQL\MySQL Server 5.6 3. 新建my.ini. 加入如下配置: ...

  10. WPF绑定时要绑定属性,不要绑定字段

    如题(就是加get;set;),绑定属性不出东西,不知道为什么...