Create DataRelation ship between two tables

本文通过一个简单的DataSet示例展示了如何使用DataRelation类建立表间关系,并遍历子行。该示例包括创建DataTable、添加列和行,以及使用.NET Framework 1.1和2.0的不同方法来设置关系。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

There is a simple demo for DataRelation class of DataSet.

while u can use DataTable.Select(conditions) or DataView.Filter to filete the data what you want .however,maybe the method is more complex with this one.


datatalbeperformancetest#regiondatatalbeperformancetest

/**////<summary>
///Testtablerelation.
///</summary>

publicvoidRelation()
...{
DataTabledtParent
=this.CreateDataTable();
dtParent.TableName
="Parent";

.netframework2.0#region.netframework2.0
DataSetds
=newDataSet();
ds.Tables.Add(dtParent);
DataRelationrelations
=ds.Relations.Add("Relation",ds.Tables["Parent"].Columns["index"],ds.Tables["Parent"].Columns["parent_index"],false);

foreach(DataRowrowinds.Tables["Parent"].Rows)
#endregion


.netframework1.1#region.netframework1.1
//DataRelationrelations=newDataRelation("Relation",dtParent.Columns["index"],dtParent.Columns["parent_index"],false);
//foreach(DataRowrowindtParent.Rows)
#endregion

...{
if(0!=string.Compare(row["parent_index"].ToString(),"0",true,System.Globalization.CultureInfo.CurrentCulture))
...{
continue;
}


this.DebugPrint(string.Format("{0}",row["description"].ToString()));

this.PrintChilds(row,relations);

this.DebugPrint("--------------------------------------------------");


}

}


/**////<summary>
///printthechild
///</summary>

privatevoidPrintChilds(DataRowrowParent,DataRelationrelations)
...{
DataRow[]rowChilds
=rowParent.GetChildRows(relations);

if(null==rowChilds||0==rowChilds.Length)
...{
return;
}


stringspaces=string.Empty;
foreach(DataRowrowinrowChilds)
...{
spaces
=spaces.PadLeft(int.Parse(row["layer"].ToString()),' ');
this.DebugPrint(string.Format("{0}|--{1}",spaces,row["description"].ToString()));

this.PrintChilds(row,relations);
}

}


/**////<summary>
///Createthedatatablefortest.
///</summary>
///<returns></returns>

privateDataTableCreateDataTable()
...{
DataTabledt
=newDataTable("Test");

//addcolumns
dt.Columns.Add(newDataColumn("index",typeof(Int32)));
dt.Columns.Add(
newDataColumn("parent_index",typeof(Int32)));
dt.Columns.Add(
newDataColumn("description",typeof(string)));
dt.Columns.Add(
newDataColumn("layer",typeof(string)));

//addrows
dt.Rows.Add(newobject[]...{1000,0,"first1",0});
dt.Rows.Add(
newobject[]...{1001,1000,"secord2",1});
dt.Rows.Add(
newobject[]...{2000,0,"third3",0});
dt.Rows.Add(
newobject[]...{2001,1000,"forth4",2});
dt.Rows.Add(
newobject[]...{3000,2000,"fifth5",1});
dt.Rows.Add(
newobject[]...{3001,3000,"six6",2});
dt.Rows.Add(
newobject[]...{2222,0,"seven7",0});


dt.Rows.Add(
newobject[]...{100,2222,"first11",1});
dt.Rows.Add(
newobject[]...{101,1000,"secord21",1});
dt.Rows.Add(
newobject[]...{200,222,"third31",3});
dt.Rows.Add(
newobject[]...{201,1001,"forth41",2});
dt.Rows.Add(
newobject[]...{300,2000,"fifth51",1});
dt.Rows.Add(
newobject[]...{301,3000,"six61",2});
dt.Rows.Add(
newobject[]...{222,1000,"seven71",3});

//acceptchanges
dt.AcceptChanges();

//DataSetds=newDataSet("Test");
//ds.Tables.Add(dt);

returndt;
}


privatevoidDebugPrint(stringmsg)
...{
//System.Diagnostics.Debug.WriteLine(msg);
Console.WriteLine(msg);
}

#endregion

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值