ASP.NET 绑定DataSet中的多个表

今天在论坛遇到有人问如何在ASP.NET的数据控件中如何一次绑定多个表?这个问题,平时很少看到,一般在数据绑定之前,数据都是放在一个表中的,实际上,如果表之间存在关系,绑定多个表也是可以的。下面就是 DataSet中两个表进行绑定的例子。

查看例子

  1. <%@ Page Language="C#" %>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  3.  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  4. <script runat="server">
  5.   protected void Page_Load(object sender, EventArgs e)
  6.   {
  7.     System.Data.DataSet ds = new System.Data.DataSet();
  8.     System.Data.DataTable dataTable1 = new System.Data.DataTable("BlogUser");
  9.     System.Data.DataRow dr;
  10.     dataTable1.Columns.Add(new System.Data.DataColumn("UserId", typeof(System.Int32)));
  11.     dataTable1.Columns.Add(new System.Data.DataColumn("UserName", typeof(System.String)));
  12.     dataTable1.PrimaryKey = new System.Data.DataColumn[] { dataTable1.Columns["UserId"] };
  13.     for (int i = 0; i < 8; i++)
  14.     {
  15.       dr = dataTable1.NewRow();
  16.       dr[0] = i;
  17.       dr[1] = "【孟子E章】" + i.ToString();
  18.       dataTable1.Rows.Add(dr);
  19.     }
  20.     System.Data.DataTable dataTable2 = new System.Data.DataTable("BlogArticle");
  21.     dataTable2.Columns.Add(new System.Data.DataColumn("ArticleId", typeof(System.Int32)));
  22.     dataTable2.Columns.Add(new System.Data.DataColumn("Title", typeof(System.String)));
  23.     dataTable2.Columns.Add(new System.Data.DataColumn("UserId", typeof(System.Int32)));
  24.     dataTable2.PrimaryKey = new System.Data.DataColumn[] { dataTable1.Columns["ArticleId"] };
  25.     Random rd = new Random();
  26.     for (int i = 0; i < 20; i++)
  27.     {
  28.       dr = dataTable2.NewRow();
  29.       dr[0] = i;
  30.       dr[1] = "文章标题" + i.ToString();
  31.       dr[2] = rd.Next(0, 7);
  32.       dataTable2.Rows.Add(dr);
  33.     }
  34.     ds.Tables.Add(dataTable1);
  35.     ds.Tables.Add(dataTable2);
  36.     System.Data.DataColumn parentColumn = ds.Tables["BlogUser"].Columns["UserId"];
  37.     System.Data.DataColumn childColumn = ds.Tables["BlogArticle"].Columns["UserId"];
  38.     System.Data.DataRelation user_article = new System.Data.DataRelation("UserId", parentColumn, childColumn);
  39.     ds.Relations.Add(user_article);
  40.     this.Repeater1.DataSource = ds.Tables["BlogArticle"].DefaultView;
  41.     this.Repeater1.DataBind();
  42.   }
  43. </script>
  44. <html xmlns="http://www.w3.org/1999/xhtml">
  45. <head id="Head1" runat="server">
  46.   <title>【孟宪会之精彩世界】- ASP.NET 绑定DataSet中的多个表 作者:孟子E章</title>
  47. </head>
  48. <body>
  49.   <form id="form1" runat="server">
  50.   <asp:Repeater ID="Repeater1" runat="server">
  51.     <HeaderTemplate>
  52.       <table border="1">
  53.         <tr style="background:orange">
  54.           <th>文章标题</th>
  55.           <th>用户ID</th>
  56.           <th>用户名</th>
  57.         </tr>
  58.     </HeaderTemplate>
  59.     <FooterTemplate>
  60.       </table></FooterTemplate>
  61.     <ItemTemplate>
  62.       <tr>
  63.         <td><%#Eval("Title")%></td><td><%#Eval("UserId") %></td>
  64.         <td><%#(Container.DataItem as System.Data.DataRowView).Row.GetParentRow("UserId")["UserName"]%>
  65.         </td>
  66.       </tr>
  67.     </ItemTemplate>
  68.   </asp:Repeater>
  69.   </form>
  70. </body>
  71. </html>
  • 0
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 10
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值