多くの行を持つデータベースにテーブルがある場合は、 と通常の行(Gridviewではなく)で表示したいと考えています。同様: クラス1/1、2/1、クラス、クラス3/1DBから多くの行を通常の行で表示しますか?
我々が取る(1/1と2/1と3/1)から:
あなたはこれらのクラスを教えますデータベース。
どうすればいいですか?
注:私はLINQを使ってデータベースを扱います。
多くの行を持つデータベースにテーブルがある場合は、 と通常の行(Gridviewではなく)で表示したいと考えています。同様: クラス1/1、2/1、クラス、クラス3/1DBから多くの行を通常の行で表示しますか?
我々が取る(1/1と2/1と3/1)から:
あなたはこれらのクラスを教えますデータベース。
どうすればいいですか?
注:私はLINQを使ってデータベースを扱います。
リピーターを使用するのが私にとって最も簡単な方法です。それはこのようなものに見えるでしょう。
<div>
You teach these classes:
<asp:Repeater
ID="rptListOfClasses"
runat="server"
DataSourceID="linqDataSource" >
<ItemTemplate>
<span> class <%# Eval("ClassDate") %>, </span>
</ItemTemplate>
</asp:Repeater>
</div>
<asp:ListView ID="lvClass" runat="server" DataSourceID="LinqDataSource1" OnItemDataBound ="lvResult_ItemDataBound" >
<LayoutTemplate>
You teach these classes:
<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;
}
}