2009-06-04 7 views
1

多くの行を持つデータベースにテーブルがある場合は、 と通常の行(Gridviewではなく)で表示したいと考えています。同様: クラス1/1、2/1、クラス、クラス3/1DBから多くの行を通常の行で表示しますか?

我々が取る

(1/1と2/1と3/1)から:

あなたはこれらのクラスを教えますデータベース。

どうすればいいですか?

注:私はLINQを使ってデータベースを扱います。

答えて

1

リピーターを使用するのが私にとって最も簡単な方法です。それはこのようなものに見えるでしょう。

<div> 
    You teach these classes: 
    <asp:Repeater 
     ID="rptListOfClasses" 
     runat="server" 
     DataSourceID="linqDataSource" > 
     <ItemTemplate> 
      <span> class <%# Eval("ClassDate") %>, </span> 
     </ItemTemplate> 
    </asp:Repeater> 
</div> 
0
<asp:ListView ID="lvClass" runat="server" DataSourceID="LinqDataSource1" OnItemDataBound ="lvResult_ItemDataBound" > 
    <LayoutTemplate> 
     You teach these classes:&nbsp; 
     <asp:PlaceHolder runat="server" ID="itemPlaceHolder" ></asp:PlaceHolder> 
    </LayoutTemplate> 
    <ItemTemplate> 
      <asp:Label ID="lblClass" runat="server" Text='<%# DataBinder.Eval(Container.DataItem, "Class") + ", " %>' ></asp:Label>           
    </ItemTemplate> 

</asp:ListView> 


<asp:LinqDataSource ID="LinqDataSource1" runat="server" 
    ContextTypeName="MyDataContext" TableName="ClassList" 
    onselected="LinqDataSource1_Selected"> 
</asp:LinqDataSource> 

背後にあるコード: //(、)最後のコンマを削除

public class Test : System.Web.UI.Page 
    { 
     int iCount = 0; 
protected void lvResult_ItemDataBound(object sender, ListViewItemEventArgs e) 
     { 
      if (e.Item.ItemType == ListViewItemType.DataItem) 
      { 

       Label lblClass = e.Item.FindControl("lblClass") as Label; 
       ListViewDataItem lvItem = e.Item as ListViewDataItem ; 
       if (lblClass != null) 
        if (lvItem.DataItemIndex == (iCount - 1)) 
         lblClass.Text = lblClass.Text.Substring(0, lblClass.Text.ToString().Length - 2); 



      } 
     } 

     protected void LinqDataSource1_Selected(object sender, LinqDataSourceStatusEventArgs e) 
     { 
      iCount = e.TotalRowCount; 
     } 

} 
関連する問題