DataSet与DataTable基本用法
http://files.cnblogs.com/files/monkeyZhong/DataSetExample.rar
在设计数据库操作或者XML操作等表格数据时,我们难免要跟DataSet和DataTable打交道,我们这里就介绍下这几个类的用法:
首先介绍DataTable,其实就是一个二维表格,没那么悬乎,举个构造的例子:
DataTable dt = new DataTable("Customers");
dt.Columns.Add("CustomerID", typeof(Int32));
dt.Columns.Add("CustomerName", typeof(String));
dt.Columns.Add("Description", typeof(string));
DataRow row = dt.NewRow();
row[0] = 001;
row[1] = "大众";
row[2] = "中档车";
dt.Rows.Add(row);
DataRow row2 = dt.NewRow();
row2[0] = 002;
row2[1] = "奔驰";
row2[2] = "豪车";
dt.Rows.Add(row2);
这就构造了一个二行三列的二维表了。
其次就是DataSet:我们可以把它看做是DataTable的集合容器,我们可以往里面添加很多表。比如:
customerOrders = new DataSet();
customerOrders.Tables.Add(customerTable);
customerOrders.Tables.Add(orderTable);
customerOrders.Tables.Add(orderDetailTable);
customerOrders.Tables.Add(ProductTable);
这里就添加了四个表。
当然,DataSet还有其他的内容,这里我平时用得少但是很重要的地方就是DataRelation,这个我们可以想成表与表之间通过某列来建立一个联系,这样我们就可以通过某行的GetChildRows得到子列的行集合(满足关系),或者通过GetParentRow得到父列的行。
DataRelation customerOrdersRelation = new DataRelation("CustOrders",
customerOrders.Tables["Customers"].Columns["CustomerID"],
customerOrders.Tables["Orders"].Columns["CustomerID"]);
customerOrders.Relations.Add(customerOrdersRelation);
DataRelation orderDetailRelation = customerOrders.Relations.Add("OrderDetail",
customerOrders.Tables["Orders"].Columns["OrderID"],
customerOrders.Tables["OrderDetails"].Columns["OrderID"], false);
DataRelation orderProductRelation = customerOrders.Relations.Add("OrderProducts",
customerOrders.Tables["Product"].Columns["ProductID"],
customerOrders.Tables["OrderDetails"].Columns["ProductID"]);
DataRow[] rows = customerOrders.Tables["Customers"].Rows[].GetChildRows(customerOrdersRelation);
DataTable dt = orderTable.Clone();
foreach (DataRow row in rows)
{
dt.ImportRow(row);
}
StringBuilder sw = new StringBuilder();
foreach (DataRow custRow in customerOrders.Tables["Customers"].Rows)
{
sw.AppendLine("Customer ID:" + custRow["CustomerID"]);
foreach (DataRow orderRow in custRow.GetChildRows(customerOrdersRelation))
{
sw.AppendLine(" Order ID:" + orderRow["OrderID"]);
sw.AppendLine("\tOrder Date:" + orderRow["DateTime"]);
foreach (DataRow detailRow in orderRow.GetChildRows(orderDetailRelation))
{
sw.AppendLine("\tProduct" + detailRow.GetParentRow(orderProductRelation)["ProductName"]);
}
}
}
子行可以有很多,但是父行只有一行。
至于那些外键,主键,约束,以及更新表的时候的一些操作,因为涉及到数据库的很多知识,这里就不做描述了,我们侧重这两个类的用法。
DataSet与DataTable基本用法的更多相关文章
- dataset 和DataTable的用法
以下包含了这两种不同属性的用法: foreach (DataRow dr in dataset.Tables[0].Rows) { if (i != 0 && l ...
- C# DataSet与DataTable的区别和用法 ---转载
C# DataSet与DataTable的区别和用法 转载:https://www.cnblogs.com/liuyi-li/p/6340411.html DataSet是数据集,DataTable是 ...
- C# DataSet与DataTable的区别和用法
DataSet是数据集,DataTable是数据表,DataSet存储多个DataTable.DataSet和DataTable像是专门存储数据的一个容器,在你查询数据库得到一些结果时可以存在里面. ...
- DataTable.Compute()用法
DataTable.Compute()用法 2010-04-07 11:28 一.DataTable.Compute()方法說明如下 作用: 计算用来传递筛选条件的当前行上的给定表达 ...
- 关于PagedDataSource分页属性与DataSet和DataTable详解
Asp.net提供了三个功能强大的列表控件:DataGrid.DataList和Repeater控件,但其中只有DataGrid控件提供分页功能.相对DataGrid,DataList和Repeate ...
- DataSet、DataTable、DataRow 复制
DataSet.DataTable.DataRow 复制 DataSet 对象是支持 ADO.NET的断开式.分布式数据方案的核心对象 ,用途非常广泛.我们很多时候需要使用其中的数据,比如取得一个Da ...
- C# DataTable.Compute()用法
DataTable.Compute()用法 2010-04-07 11:28 一.DataTable.Compute()方法說明如下 作用: 计算用来传递筛选条件的当前行上的给定表达 ...
- ADO.NET中DataSet、DataTable、DataRow的数据复制方法
DataSet 对象是支持 ADO.NET的断开式.分布式数据方案的核心对象 ,用途非常广泛.我们很多时候需要使用其中的数据,比如取得一个DataTable的数据或者复制另一个DataTabe中的数据 ...
- DataSet、DataTable、DataRow的数据复制方法
DataSet 对象是支持 ADO.NET的断开式.分布式数据方案的核心对象 ,用途非常广泛.我们很多时候需要使用其中的数据,比如取得一个DataTable的数据或者复制另一个DataTabe中的数据 ...
随机推荐
- 关于IOS开发者账号一点总结
经过查阅相关资料,我扼要总结了以下几点内容. 一.开发者账号类型 个人账号 99美金/年 公司账号 99 企业账号 299 教育账号 0 二.开发者账号有无比较 如果有: 可以真机测试 发布的应用可以 ...
- Coach(并查集)
Description A programming coach has n students to teach. We know that n is divisible by 3. Let's ass ...
- bzoj1853 bzoj2393
两题是类似的,这里说一下bzoj1853 首先我们求出所有的幸运号码,注意如果存在x是y的倍数则x不算在内,避免之后重复计算 下面我们就要统计幸运号码的倍数了,这显然是要用到容斥原理的 但是幸运号码很 ...
- Maven学习(1) - Maven入门
home index:http://maven.apache.org/ download:http://maven.apache.org/download.cgi install: http://ma ...
- (转载)Android开发者必知的开发资源
(转载)http://www.importnew.com/3988.html 随着Android平台市场份额的持续猛增 ,越来越多的开发者开始投入Android应用程序的开发大潮.如果您是一位2013 ...
- 《University Calculus》-chaper8-无穷序列和无穷级数-泰勒定理的证明
泰勒定理: 证明:
- hdoj 2647 Reward【反向拓扑排序】
Reward Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- BFS-hdu-4101-Ali and Baba
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4101 题目大意: 给一个矩阵,0表示空的可走,-1宝藏的位置(只有一个),其余的正整数表示该位置石头 ...
- shell 验证ip
#!/bin/bash function isIp(){ IP=$ ];then echo "Wrong IP!" exit else a=`echo $IP | awk -F . ...
- Amoeba实现mysql主从读写分离
Amoeba实现mysql主从读写分离 这段在网上看了下关于amoeba的文章,总体感觉好像要比mysql-proxy好的多,也参考了不少的资料,此文章可能与其他文章作者会有雷同的地方,请谅解,但是此 ...