C# - 自定义 DataSet 的使用
------------------------------------------------- SellProdectManager.cs ---------------------------------------------------
using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
namespace Prodect.BLL
{
public class SellProdectManager
{
public static DataSet GetSellProdectDataSet() {
DataSet ds = new DataSet();//新建一个 DataSet
DataTable sellProdect = new DataTable("SellProdect");//新建一个 DataTable
DataColumn id = new DataColumn("Id", typeof(int));//新建 Id 列
id.AutoIncrement = true;//设置该列为自赠列
id.AutoIncrementSeed = 1;//设置该列的起始值
id.AutoIncrementStep = 1;//设置自赠的步长
DataColumn name = new DataColumn("Name",typeof(String));//新建 Name 列
name.AllowDBNull = false;//设置该列是否允许为空
DataColumn repertory = new DataColumn("Repertory",typeof(String));
repertory.AllowDBNull = false;
//往 DataTable(sellProdect) 的列集合填充新建的列
sellProdect.Columns.AddRange(new DataColumn[] { id, name, repertory });
//创建与 DataTable(sellProdect) 结构相同的行
DataRow row = sellProdect.NewRow();
row["Name"] = "电冰箱";
row["Repertory"] = 21;
//往 DataTable(sellProdect) 的行集合填充新建的行
sellProdect.Rows.Add(row);
//往 DataSet(ds) 的表集合填充 DataTable(sellProdect) 的这个新建的表
ds.Tables.Add(sellProdect);
// DataSet(ds) 更改确认
ds.AcceptChanges();
return ds;
}
}
}
---------------------------------------------------- Prodect.cs -------------------------------------------------------
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using Prodect.BLL;
namespace Prodect
{
public partial class Prodect : Form
{
public Prodect()
{
InitializeComponent();
}
DataSet _sellProdect = null;
//窗体加载触发的事件
private void Prodect_Load(object sender, EventArgs e)
{
//获得 DataSet
_sellProdect = SellProdectManager.GetSellProdectDataSet();
//绑定 DataGridView 数据源
dgvSell.DataSource = _sellProdect.Tables["SellProdect"];
}
//行状态发生改变触发的事件
private void dgvSell_RowStateChanged(object sender, DataGridViewRowStateChangedEventArgs e)
{
if (dgvSell.SelectedRows.Count == 0)
return;
//获得当前 DataGridView 所选择的行
DataGridViewRow row = dgvSell.SelectedRows[0];
//获取用于填充行的数据绑定对象,然后强制转换成(DataRowView)
DataRowView rv = row.DataBoundItem as DataRowView;
txtName.Text = rv["Name"].ToString();
txtPrice.Text = rv["Price"].ToString();
txtCount.Text = rv["Repertory"].ToString();
}
//删除按钮事件
private void btnDel_Click(object sender, EventArgs e)
{
if (dgvSell.SelectedRows.Count == 0)
return;
//获得当前 DataGridView 所选择的行
DataGridViewRow row = dgvSell.SelectedRows[0];
//获取用于填充行的数据绑定对象,然后强制转换(DataRowView)
DataRowView rv = row.DataBoundItem as DataRowView;
//删除选择的该行
rv.Delete();
}
//保存修改按钮事件
private void btnSave_Click(object sender, EventArgs e)
{
//DataSet(_sellProdect) 确认更新
_sellProdect.AcceptChanges();
}
//撤消修改按钮事件
private void btnReject_Click(object sender, EventArgs e)
{
//DataSet(_sellProdect) 撤消更新
_sellProdect.RejectChanges();
}
}
}
C# - 自定义 DataSet 的使用的更多相关文章
- 自定义DataSet
//创建数据集 DataSet dataSet = new DataSet(); //创建虚拟数据表 DataTable datatable = new DataTable(); //获取列集合,添加 ...
- DataSet和DataTable详解
先构建一个结构与用户请求数据结构相同的DataTable,然后将用户的请求数据填充到构建好的DataTable中,最后将DataTable添加到DataSet中. DataTable,,DataCol ...
- [Pytorch]PyTorch Dataloader自定义数据读取
整理一下看到的自定义数据读取的方法,较好的有一下三篇文章, 其实自定义的方法就是把现有数据集的train和test分别用 含有图像路径与label的list返回就好了,所以需要根据数据集随机应变. 所 ...
- 解析大型.NET ERP系统架构设计 Framework+ Application 设计模式
我对大型系统的理解,从数量上面来讲,源代码超过百万行以上,系统有超过300个以上的功能,从质量上来讲系统应该具备良好的可扩展性和可维护性,系统中的功能紧密关联.除去业务上的复杂性,如何设计这样的一个协 ...
- 《项目经验》--通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来的Json数据写入数据库表中
先看一下我要实现的功能界面: 这个界面的功能在图中已有展现,课程分配(教师教授哪门课程)在之前的页面中已做好.这个页面主要实现的是授课,即给老师教授的课程分配学生.此页面实现功能的步骤已在页面 ...
- 通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来的Json数据写入数据库表中
摘自:http://blog.csdn.net/mazhaojuan/article/details/8592015 通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来 ...
- NET ERP系统架构设计
解析大型.NET ERP系统架构设计 Framework+ Application 设计模式 我对大型系统的理解,从数量上面来讲,源代码超过百万行以上,系统有超过300个以上的功能,从质量上来讲系统应 ...
- 一个操作oracle的c#类 含分页
有别于以前的一个OracleHelper,这个版各有所长,MARK下. using System; using System.Data; using System.Data.OracleClient; ...
- [深度学习] pytorch利用Datasets和DataLoader读取数据
本文简单描述如果自定义dataset,代码并未经过测试(只是说明思路),为半伪代码.所有逻辑需按自己需求另外实现: 一.分析DataLoader train_loader = DataLoader( ...
随机推荐
- C#中关键字ref与out的区别【转】
在C#中,ref与out是很特殊的两个关键字.使用它们,可以使参数按照引用来传递.总的来说,通常我们向方法中传递的是值.方法获得的是这些值的一个拷贝,然后使用这些拷贝,当方法运行完毕后,这些拷贝将被丢 ...
- 解决Win7&Win8 64位下Source Insight提示未完整安装的问题
网上的破解版的注册表文件都是针对32位系统的,所以在64位系统里运行根本无法破解.下面分别贴出这俩系统里的破解文件. 使用方法: 分别复制对应系统的内容,新建文本文档,将内容粘贴进去,重命名为.reg ...
- 【稳定婚姻问题】【HDU1435】【Stable Match】
2015/7/1 19:48 题意:给一个带权二分图 求稳定匹配 稳定的意义是对于某2个匹配,比如,( a ---- 1) ,(b----2) , 如果 (a,2)<(a,1) 且(2,a)& ...
- jQuery事件绑定方法bind、 live、delegate和on的区别
我们试图绑定一些事件到DOM元素上的时候,我相信上面这4个方法是最常用的.而它们之间到底有什么不同呢?在什么场合下用什么方法是最有效的呢? 1.准备知识 当我们在开始的时候,有些知识是必须具备的: 1 ...
- PHP定义数组常量
最先想到的方法是这样: define('SIGN_CODE', array('9df512','59gf1g','5eg7h1','g1agf5','f5e151','g51gfr','a5481s' ...
- C# 根据年月获得此月第一天和最后一天,并计算工作日
string str = "2015年3月"; ); ); , secondIndex - firstIndex - ); , ); DateTime dt = DateTime. ...
- Ubuntu 13.10 下安装node
1.首先更新Ubuntu在线包:sudo apt-get update && sudo apt-get dist-upgrade, 2.默认Ubuntu已经安装python的,具体版本 ...
- Struts2 访问web元素
访问web元素的四种方法(耦合,依赖注入).(耦合,非依赖注入).(非耦合,依赖注入).(非耦合,非依赖注入) 耦合:可以得到HttpServletResponse,HttpServletReques ...
- DW 图片不显示的情况 ———网页只显示字不显示图片的情况 目录下的图片名被改动不显示图片的情况
例子1-- 酒瓶子 alt 在不现实图片的情况下显示汉字 图文效果展示 alt 1************************* 语句---- <body> < ...
- nginx1.9.4 +php 5.5.29+yii2.0配置手册
nginx1.9.4 +php 5.5.29+yii2.0配置手册 目录 一. php5.5.29安装配置 2 二. nginx1.9.4安装配置 2 三. yii2.0 ...