using System;

using System.Collections.Generic;

using System.Text;

using System.Data;

namespace connect

{

class Program

{

static void Main(string[] args)

{

//建立数据集对象,像数据库一样

DataSet ds=new DataSet() ;

//建立表

DataTable dtsb = new DataTable("SB");

DataTable dtsx = new DataTable("SX");

//SB主表,创建列

dtsb.Columns.Add(new DataColumn("学号"));

dtsb.Columns.Add(new DataColumn("姓名"));

dtsb.Columns.Add(new DataColumn("性别"));

dtsb.Columns.Add(new DataColumn("总成绩"));

//SX从表,创建列

dtsx.Columns.Add(new DataColumn("学号"));

dtsx.Columns.Add(new DataColumn("姓名"));

dtsx.Columns.Add(new DataColumn("科目"));

dtsx.Columns.Add(new DataColumn("分成绩"));

//主表数据,创建行

dtsb.Rows.Add("1","陈一","男","100");

dtsb.Rows.Add("2", "王二", "女", "90");

dtsb.Rows.Add("3", "李三", "女", "80");

dtsb.Rows.Add("4", "赵四", "男", "70");

//从表数据,创建行

dtsx.Rows.Add("1", "陈一", "语文", "50");

dtsx.Rows.Add("1", "陈一", "数学", "50");

dtsx.Rows.Add("2", "王二", "数学", "90");

dtsx.Rows.Add("3", "李三", "历史", "50");

dtsx.Rows.Add("3", "李三", "地理", "30");

dtsx.Rows.Add("4", "赵四", "英文", "70");

//输出主表明细

Console.WriteLine("我是SB");

Console.WriteLine("学号 姓名 性别 总成绩");

foreach (DataRow a in dtsb.Rows)

{

Console.WriteLine("{0} {1} {2} {3}", a[0].ToString().PadRight (4,' '),a[1],a[2].ToString().PadRight (4,' '),a[3]);

}

Console.WriteLine("");

//输出从表明细

Console.WriteLine("我是SX");

Console.WriteLine("学号 姓名 科目 分成绩");

foreach (DataRow a in dtsx.Rows)

{

Console.WriteLine("{0} {1} {2} {3}", a[0].ToString().PadRight (4, ' '), a[1], a[2].ToString().PadRight(4, ' '), a[3]);

}

Console.WriteLine("");

//把表添加到dataset

ds.Tables.Add(dtsb);

ds.Tables.Add(dtsx);

//创建关系,以学号为主键

ds.Relations.Add("SBX", ds.Tables["SB"].Columns["学号"], ds.Tables["SX"].Columns["学号"]);

//历遍主表所有行,将其赋值给drsb

foreach (DataRow drsb in ds.Relations["SBX"].ParentTable.Rows)

{

Console.WriteLine("{0} {1} {2} {3}", drsb[0], drsb[1], drsb[2], drsb[3]);

//历遍drsb所有子行,将其赋值给drsx

foreach (DataRow drsx in drsb.GetChildRows("SBX"))

{

Console.WriteLine(" {0} {1} {2} {3}",drsx[0],drsx[1],drsx[2],drsx[3]);

}

}

}

}

}

关于DataSet中Relations的应用的更多相关文章

  1. DataSet中的relation

    DataSet中的relation DataSet是ADO.Net中相当重要的数据访问模型.有一个很大的优点是可以记录多个表之间的关系.有点类似与数据库的外键. 在DataSet中也可以定义类似的关系 ...

  2. C# 导入Excel到DataSet中

    class Import { /// <summary> /// 导入Excel到DataSet中 /// </summary> /// <param name=&quo ...

  3. 使用OpenXml把Excel中的数据导出到DataSet中

    public class OpenXmlHelper { /// <summary> /// 读取Excel数据到DataSet中,默认读取所有Sheet中的数据 /// </sum ...

  4. DataSet 中的数据排序 及 DataRow装成DataTable

    1.DataSet 中的数据排序 DataSet ds = new DataSet(); // 获取当前排口的数据 ds = _xiaobill.GetHistoryData(yinZiBianm, ...

  5. DataSet中取值(转)

    1 DataSet.Table[0].Rows[ i ][ j ] 其中i 代表第 i 行数, j 代表第 j 列数 2 DataSet.Table[0].Rows[ i ].ItemArray[ j ...

  6. 在DATASET中要是想添加进另一个表怎么办?

    问:sql="select * from banzhu_manage ";adapter=new SqlDataAdapter(sql,banzhu_conn);adapter.F ...

  7. C# 手动编写 DataSet,DataTable 及遍历DataSet中的数据

    一.手动编写DataSet:    有时候不想从数据库导出 DataSet,或者有其他的需要,要将数据库里的DataSet包装成另一个样子,这个时候,了解DataSet的内部结构就非常必要.DataS ...

  8. C#中DataSet中的relation

    //关系定义的方法是 DataRelation 变量名 = “DataSet对象”.Relations.Add("关系名",DataSet对象.主表.列名 , DataSet对象. ...

  9. 导入本地Excel到DataSet中

    /// <summary> /// 导入本地Excel到DataSet中 /// </summary> /// <param name="strFileSour ...

随机推荐

  1. Leetcode_66_Plus One

    本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/41652987 Plus One Given a non-n ...

  2. (六十二)纯代码搭建UI

    在Xcode6中,去掉了Empty Application的选项,因此可以通过先创建SingleView,再删除storyboard,并且把工程设置中的main Interface清空. 通过AppD ...

  3. HTML5进阶(二)HBuilder实现软件自动升级

    HBuilder实现软件自动升级 前言 移动APP开发好后需要实现软件自动升级功能,经过一番搜索,发现HBuilder具有"App资源在线升级更新"的功能,遂研究之. 经过一番测试 ...

  4. 如何设计一个web容器

    开发一个web容器涉及很多不同方面不同层面的技术,例如通信层的知识,程序语言层面的知识等等,且一个可用的web容器是一个比较庞大的系统,要说清楚需要很长的篇幅,本文旨在介绍如何设计一个web容器,只探 ...

  5. Android的内存分配与回收

    想写一篇关于android的内存分配和回收文章的想法来源于追查一个魅族手机图片滑动卡顿问题,我们想了很多办法还是没有避免他不停的GC,所以就打算详细的看看内存分配和GC的原理,为什么会不断的GC,GC ...

  6. C语言中 sscanf 的用法

    名称: sscanf() - 从一个字符串中读进与指定格式相符的数据. 函数原型: Int sscanf( string str, string fmt, mixed var1, mixed var2 ...

  7. 广义线性模型 R--glm函数

    R语言glm函数学习:  [转载时请注明来源]:http://www.cnblogs.com/runner-ljt/ Ljt 作为一个初学者,水平有限,欢迎交流指正. glm函数介绍: glm(for ...

  8. Leetcode_136_Single Number

    本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/42713315 Given an array of inte ...

  9. SpriteBuilder全屏弹出菜单的特殊效果

    但是等一下!这里可以有更多.对于全屏的弹出菜单,你可以在显示弹出全屏菜单时朦胧化背景的level视图. 通过修改SpriteBuilder中的color节点的Color属性(比如修改为black)和O ...

  10. Jenkins hash

    最早,Bob Jenkins提出了多个基于字符串通用Hash算法(搜Jenkins Hash就知道了),而Thomas Wang在Jenkins的基础上,针对固定整数输入做了相应的Hash算法.其64 ...