在代码里面我自己建立了一个表
         Dim dt As New DataTable
        dt.Columns.Add("a", GetType(Double))
        dt.Columns.Add("b", GetType(Double))
        dt.Columns.Add("c", GetType(Double))
        dt.Columns.Add("d", GetType(Double))
        dt.Columns.Add("e", GetType(Double))
        dt.Columns.Add("f", GetType(Double))通过循环把记录集的数据一条一条写入表
For i As Integer = 0 To ds.Tables(0).Rows.Count - 1
            dr(0) = dsU.Tables(0).Rows(0)(“a”).ToString()
            dr(1) = dsU.Tables(0).Rows(0)("b").ToString()
            dr(2) = dsU.Tables(0).Rows(0)("c").ToString()
            dr(3) = dsU.Tables(0).Rows(0)("d").ToString()
            dr(4) = dsU.Tables(0).Rows(0)("e").ToString()
            dr(5) = dsU.Tables(0).Rows(0)("f").ToString()我需要写入的数据按dr(5)字段重小到大的写入表再绑定到repeater控件上
            dt.Rows.Add(dr)
Next
        repeater.DataSource = dt
        repeater.DataBind()
说白了就是要按字段f排序显示

解决方案 »

  1.   

    DataView dv = dt.DefaultView
    dv.Sort = "f desc"repeater.DataSource = dv;
    repeater.DataBind();
      

  2.   

    <asp:Repeater ID="Repeater1" runat="server" OnItemCommand="Repeater1_ItemCommand"> 
    <HeaderTemplate> 
    <table width=50%> 
    <tr> 
    <td style="width:20%">大类名称</td> 
    <td style="width:20%">大类说明</td> 
    <td style="width:10%">编辑</td> 
    </tr> 
    </HeaderTemplate> 
    <ItemTemplate> 
    <tr> 
    <td style="width:20%"><asp:LinkButton ID="Label1" CommandArgument='<%#Bind("BigCategoies_ID") %>' CommandName="name" runat="server" Text='<%#Bind("BigCategoies_Name") %>'/></td> 
    <td style="width:20%"><asp:LinkButton ID="Label2" CommandArgument='<%#Bind("BigCategoies_ID") %>' CommandName="name" runat="server" Text='<%# Eval("BigCategoies_Note").ToString().Length>10?Eval("BigCategoies_Note").ToString().Substring(0,10)+"...":Eval("BigCategoies_Note") %>'/></td> 
    <td style="width:10%"> 
    <a href='updateBigCategoies.aspx?id=<%#Eval("BigCategoies_ID") %>'> 
    <img src='../images/edit.gif' width="20" height="18" /></a> 
    </td> 
    </tr> 
    </ItemTemplate> 
    <FooterTemplate> 
    </table> 
    </FooterTemplate> 
    </asp:Repeater>
      

  3.   

    在一般的网站中浏览类别的用户控件通常都位于大多数 ASP.NET 页的左边,它使用户能够按类别快速的查找产品。最近遇到一个客户,因为在他网站上展示的产品并不多,所以要求在原有类别浏览的基础上将产品也加进去。一来更方便,二来加长了左部导航栏的长度使页面更协调。原有的分类导航栏是由Repeater实现的,现在需要在每一个分类下加入该类的商品信息,于是我想到了在原有Repeater中嵌套Repeater。实现界面如下: 
     
    前台页面部分: 
    <asp:Repeater id="rptCategories" runat="server"> 
      <HeaderTemplate> 
        <table width="100%" border="0" cellspacing="0" cellpadding="0"> 
      </HeaderTemplate> 
      <ItemTemplate> 
        <!--分类名称--> 
        <tr><th><%# DataBinder.Eval(Container.DataItem, "TypeName") %></th></tr> 
        <!--分类下的产品--> 
        <asp:Repeater id="rptProduct" runat="server"> 
          <ItemTemplate> 
            <tr><td><a href='ProductInfo.aspx?Id=<%# DataBinder.Eval(Container.DataItem, "ID") %>'><%# DataBinder.Eval(Container.DataItem, "ProductName") %></a></td></tr> 
          </ItemTemplate> 
        </asp:Repeater> 
      </ItemTemplate> 
      <FooterTemplate> 
        </table> 
      </FooterTemplate> 
    </asp:Repeater> 后台代码部分(部分代码): 
    //在绑定分类品名时,绑定分类下的产品 
    private void rptCategories_ItemDataBound(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e) 

        BLL.Products products =new BLL.Products(); 
        if (e.Item.ItemType == ListItemType.Item ||    e.Item.ItemType == ListItemType.AlternatingItem)  
        { 
            Repeater rptProduct = (Repeater) e.Item.FindControl("rptProduct"); 
            //找到分类Repeater关联的数据项 
            DataRowView rowv = (DataRowView)e.Item.DataItem; 
            //提取分类ID 
            int CategorieId = Convert.ToInt32(rowv["ID"]); 
            //根据分类ID查询该分类下的产品,并绑定产品Repeater 
            rptProduct.DataSource = products.GetProductsByCategorieId(CategorieId); 
            rptProduct.DataBind(); 
        } 

      

  4.   

    用DataTable、DataSet汇总一下,这是ADO.net的好特性