DataRelation的用法(1)

class Program
    {
        static void Main(string[] args)
        {
            SqlConnection thisConnection = new SqlConnection(
                  @"Data Source=.\SQLEXPRESS;" +
                  @"AttachDbFilename='C:\SQL Server 2000 Sample Databases\NORTHWND.MDF';"
                  +
                  @"Integrated Security=true;Connect Timeout=30;User Instance=true");


            DataSet thisDataSet = new DataSet();
            //为每一张表创建一个DataAdapter对象,然后填充DataSet
            SqlDataAdapter custAdapter = new SqlDataAdapter(
                "select * from Customers", thisConnection);
            SqlDataAdapter orderAdapter = new SqlDataAdapter(
                "select * from Orders", thisConnection);
            custAdapter.Fill(thisDataSet, "Customers");
            orderAdapter.Fill(thisDataSet, "Orders");
            //创建DataRelation对象并将其连接到DataSet上。注:Customers是主表,Orders是子表
            DataRelation custOrderRel = thisDataSet.Relations.Add("CustOrders",
                thisDataSet.Tables["Customers"].Columns["CustomerID"],
                thisDataSet.Tables["Orders"].Columns["CustomerID"]);


            foreach (DataRow custRow in thisDataSet.Tables["Customers"].Rows)
            {
                Console.WriteLine("Customer ID:" + custRow["CustomerID"] +
                    "Name:" + custRow["CompanyName"]);
                //给定父表中的一行,获取子表与其对应的所有行,如果父表的CustomerID为5,则下面这句可以翻译成
                //select * OrderID from Orders where CustomerID=5
                foreach (DataRow orderRow in custRow.GetChildRows(custOrderRel))
                {
                    Console.WriteLine("Order ID:" + orderRow["OrderID"]);
                }
            }
            thisConnection.Close();
            Console.WriteLine();
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值