使用嵌套转发器显示部分分层数据

时间:2010-10-13 20:26:17

标签: c# sql-server-2005 nested nested-repeater

我很亲密,但到目前为止。 我有两个表,一个用于发布详细信息,另一个用于类别邻接列表。

我正在尝试使用嵌套转发器显示完整数据集(除非有更好的方法) 我正在构建我的DataSet,如下所示:

string strSql = "SELECT category_id, parent_id, cat_name_en " +
                "FROM categories;" +
                "SELECT pub_id, title_en, category_id " +
                "FROM publications;";

SqlConnection conn = new SqlConnection(connString.ConnectionString);
SqlDataAdapter da = new SqlDataAdapter(strSql, conn);

DataSet _ds = new DataSet();   
da.Fill(_ds);
_ds.DataSetName = "categories";
_ds.Tables[0].TableName = "category";
_ds.Tables[1].TableName = "publications";

_ds.Relations.Add("ParentChild", 
                  _ds.Tables["category"].Columns["category_id"],
                  _ds.Tables["category"].Columns["parent_id"], false);
_ds.Relations[0].Nested = true;

_ds.Relations.Add("CategoryMembers", 
                  _ds.Tables["category"].Columns["category_id"],
                  _ds.Tables["publications"].Columns["category_id"], false);
_ds.Relations[1].Nested = true;


categoryRepeater.DataSource = _ds.Tables["category"];
categoryRepeater.DataBind();

我正在显示如下数据:

<asp:Repeater runat="server" ID="categoryRepeater" EnableViewState="false">
  <ItemTemplate>
    <%# DataBinder.Eval(Container.DataItem, "category_id") %>
    <%# DataBinder.Eval(Container.DataItem, "cat_name_en") %><br />

    <asp:Repeater runat="server" EnableViewState="false"
      DataSource='<%# GetChildRelation(Container.DataItem, "CategoryMembers") %>'>  
      <ItemTemplate>
        <p><%# DataBinder.Eval(Container.DataItem, "pub_id") %>&nbsp;
           <%# DataBinder.Eval(Container.DataItem, "title_en") %></p>
      </ItemTemplate>
    </asp:Repeater>

    <asp:Repeater runat="server" EnableViewState="false" 
      DataSource='<%# GetChildRelation(Container.DataItem, "ParentChild") %>'>
      <ItemTemplate>
        <%# DataBinder.Eval(Container.DataItem, "category_id") %>
        <%# DataBinder.Eval(Container.DataItem, "cat_name_en") %><br />  
        <asp:Repeater runat="server" EnableViewState="false"
          DataSource='<%# GetChildRelation(Container.DataItem, "CategoryMembers") %>'>
          <ItemTemplate>
            <p><%# DataBinder.Eval(Container.DataItem, "pub_id") %>
               <%# DataBinder.Eval(Container.DataItem, "title_en") %></p> 
          </ItemTemplate>      
        </asp:Repeater>
      </ItemTemplate>    
    </asp:Repeater>
  </ItemTemplate>
</asp:Repeater>

我已经嵌套了这样的转发器,因为有些类别没有子类别,但仍有出版物。

所以我已经建立了关系以获得任何子类别,然后获得属于该类别的任何出版物。 我得到了他们孩子的类别列表以及属于该类别的任何出版物。

问题是我无法弄清楚如何防止某些儿童类别被视为父母。有些类别没有父母,但仍有出版物。这些类别将在其父级下正确显示,然后再作为自己的父类别

显示

如何配置表或关系,以便不将子类别视为父类?

1 个答案:

答案 0 :(得分:2)

首先,您需要使用RowFilter创建一个DataView,其中“parent_id为null”或parent_id ='',具体取决于数据是什么

接下来绑定dataview而不是表。

e.g。

DataView dv = new DataView(_ds.Tables["category"]);
dv.RowFilter = "parent_id is null";

categoryRepeater.DataSource = dv;

您不必触及GetChildRelation函数,因为它仍将从Container.DataItem获取DataRowView