0

次の構造のデータを含むデータテーブルがあるとします。

Revenue-Certification-1000 Revenue-IT Exam Done-1000 Acadmics-Value1-100 Acadmics-Value23-1000 ...など

私は、Revenue および Academics をキーとして辞書を返し、これらのキーの下に、他のすべての値を含む一般的なリストを返すクエリを作成しました。

ここで、1行がこのディクショナリのキーになり、このキーの下にすべての関連値があるリピーターコントロールを表示する必要があるという要件があります。

これを達成する方法を理解できません...リピーターの下のリピーターなど。リピーターまたはその他のコントロールを設計し、それに値をバインドするのを手伝ってください。前もって感謝します。

4

1 に答える 1

0

まず、@Aybe さんの返信に感謝します。

私は多くのことを試しましたが、最終的には期待どおりのものを手に入れました。

        <div>
        <table>
            <asp:Repeater ID="Repeater1" runat="server">
                <ItemTemplate>
                    <tr>
                        <td>
                            <%#Eval("Key") %>
                            <div>
                               <asp:Repeater ID="Repeater2" runat="server">
                                   <ItemTemplate>
                                        <asp:Label runat="server" ForeColor="Red" Text='<%#Eval("MetricName") %>'></asp:Label><br />
                                       <asp:Label runat="server" ForeColor="Red" Text='<%#Eval("FiscalYeartarget") %>'></asp:Label><br />
                                   </ItemTemplate>
                               </asp:Repeater>
                            </div>
                        </td>
                    </tr>
                </ItemTemplate>
            </asp:Repeater>
        </table>
    </div>

C# では、以下のようなディクショナリを作成しました。

public Dictionary<string, List<custom>> query1;
string connstr = "Data Source=(local);Initial Catalog=t;Integrated Security=True";
    string query = "SELECT * FROM [td]";
    DataTable dTable = new DataTable();

    using (SqlConnection sqlconn = new SqlConnection(connstr))
    {
        sqlconn.Open();
        SqlDataAdapter sqlda = new SqlDataAdapter(query, sqlconn);
        sqlda.Fill(dTable);

        query1 = dTable.AsEnumerable().GroupBy(x => x.Field<string>("HeaderName"))
            .ToDictionary(grp => grp.Key, x => x.Select(y => new custom()
            {
                MetricName = y.Field<string>("MetricName/KPI"),
                FiscalYeartarget = y.Field<double>("FiscalYeartarget").ToString(),
                Status = y.Field<string>("Status"),
                VTF = y.Field<double>("VTF").ToString(),
                VTF_Percent = y.Field<double>("VTF %").ToString(),
                YTDResults = y.Field<double>("YTDResults").ToString(),
                YTDTarget = y.Field<double>("YTDTarget").ToString()
            }).ToList());

        Repeater1.DataSource = query1;
        Repeater1.DataBind();

        var counter = 0;
        foreach (var x in query1)
        {
            Repeater rptr = (Repeater)Repeater1.Controls[counter].FindControl("Repeater2");
            rptr.DataSource = x.Value.ToList();
            rptr.DataBind();
            counter++;
        }
    }

そして最後に私のカスタムクラス:

public class custom
{
    public string MetricName { get; set; }
    public string FiscalYeartarget { get; set; }
    public string YTDTarget { get; set; }
    public string YTDResults { get; set; }
    public string VTF { get; set; }
    public string VTF_Percent { get; set; }
    public string Status { get; set; }
}
于 2015-03-25T08:49:12.860 に答える