zl程序教程

您现在的位置是:首页 >  后端

当前栏目

ASP.NET绑定DataSet中的多个表

NetASP 多个 绑定 Dataset
2023-06-13 09:14:07 时间

这个问题,平时很少看到,一般在数据绑定之前,数据都是放在一个表中的,实际上,如果表之间存在关系,绑定多个表也是可以的。下面就是DataSet中两个表进行绑定的例子。

复制代码代码如下:

<%@PageLanguage="C#"%>
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<scriptrunat="server">
protectedvoidPage_Load(objectsender,EventArgse)
{
System.Data.DataSetds=newSystem.Data.DataSet();
System.Data.DataTabledataTable1=newSystem.Data.DataTable("BlogUser");
System.Data.DataRowdr;
dataTable1.Columns.Add(newSystem.Data.DataColumn("UserId",typeof(System.Int32)));
dataTable1.Columns.Add(newSystem.Data.DataColumn("UserName",typeof(System.String)));
dataTable1.PrimaryKey=newSystem.Data.DataColumn[]{dataTable1.Columns["UserId"]};
for(inti=0;i<8;i++)
{
dr=dataTable1.NewRow();
dr[0]=i;
dr[1]="【孟子E章】"+i.ToString();
dataTable1.Rows.Add(dr);
}
System.Data.DataTabledataTable2=newSystem.Data.DataTable("BlogArticle");
dataTable2.Columns.Add(newSystem.Data.DataColumn("ArticleId",typeof(System.Int32)));
dataTable2.Columns.Add(newSystem.Data.DataColumn("Title",typeof(System.String)));
dataTable2.Columns.Add(newSystem.Data.DataColumn("UserId",typeof(System.Int32)));
dataTable2.PrimaryKey=newSystem.Data.DataColumn[]{dataTable1.Columns["ArticleId"]};
Randomrd=newRandom();
for(inti=0;i<20;i++)
{
dr=dataTable2.NewRow();
dr[0]=i;
dr[1]="文章标题"+i.ToString();
dr[2]=rd.Next(0,7);
dataTable2.Rows.Add(dr);
}
ds.Tables.Add(dataTable1);
ds.Tables.Add(dataTable2);
System.Data.DataColumnparentColumn=ds.Tables["BlogUser"].Columns["UserId"];
System.Data.DataColumnchildColumn=ds.Tables["BlogArticle"].Columns["UserId"];
System.Data.DataRelationuser_article=newSystem.Data.DataRelation("UserId",parentColumn,childColumn);
ds.Relations.Add(user_article);
this.Repeater1.DataSource=ds.Tables["BlogArticle"].DefaultView;
this.Repeater1.DataBind();
}
</script>
<htmlxmlns="http://www.w3.org/1999/xhtml">
<headid="Head1"runat="server">
<title>ASP.NET绑定DataSet中的多个表作者:孟子E章</title>
</head>
<body>
<formid="form1"runat="server">
<asp:RepeaterID="Repeater1"runat="server">
<HeaderTemplate>
<tableborder="1">
<trstyle="background:orange">
<th>文章标题</th>
<th>用户ID</th>
<th>用户名</th>
</tr>
</HeaderTemplate>
<FooterTemplate>
</table></FooterTemplate>
<ItemTemplate>
<tr>
<td><%#Eval("Title")%></td><td><%#Eval("UserId")%></td>
<td><%#(Container.DataItemasSystem.Data.DataRowView).Row.GetParentRow("UserId")["UserName"]%>
</td>
</tr>
</ItemTemplate>
</asp:Repeater>
</form>
</body>
</html>