0

HTML 形式で比較テーブルを作成する必要があります。問題は、データベース内のアイテムが列として表示されることですが、比較テーブルでは行でなければなりません!

データベースのデータは次のようになります

 ID  Name     Color   Weight
-------------------------------
 1   Ball     Red     10
 2   Table    Black   50
 3   Chair    Green   30

そして、比較表では次のようになります

ID      1         2        3
Name    Ball      Table    Chair
Color   Red       Black    Green
Weight  10        50       30

リピーターで ASP.NET を使用していますが、うまくいきませんでした。

比較表の列数が異なるため、リピーターのようなものを使用する必要があります。

4

2 に答える 2

0

考えられる解決策:

次の DataTable をデータソースとして指定します。

protected DataTable Data
{
    get
    {
        if (ViewState["Data"] == null)
        { 
            DataTable table = new DataTable();
            table.Columns.Add("ID", typeof(int));
            table.Columns.Add("Name");
            table.Columns.Add("Color");
            table.Columns.Add("Weight", typeof(int));

            table.Rows.Add(1, "Ball", "Red", 10);
            table.Rows.Add(2, "Table", "Black", 50);
            table.Rows.Add(3, "Chair", "Green", 30);
            ViewState["Data"] = table;
        }
        return (DataTable)ViewState["Data"];
    }
}

テーブルをループして構築するための ASP コード:

<table>
<%
  for (int i = 0; i < Data.Columns.Count; i++)
  {
        %>
        <tr>
            <td><%= Data.Columns[i].ColumnName %></td>
            <%
                for (int j = 0; j < Data.Rows.Count; j++)
                {
                    %>
                    <td><%= Data.Rows[j][i] %></td>
                    <%
                }

             %>
        </tr>
        <%  
  } 
%>
</table>
于 2013-01-25T16:45:17.277 に答える
0

したがって、これは ASP.NET 用ではありませんが、変換できる可能性があります。これは、SQL Server で動的ピボット テーブルを作成するために使用するコードです。これにより、列がいくつになるかを知らなくても、必要なことを行うことができます。ピボット テーブルに関する問題は、計算が必要なため、それを機能させるには計算を行う必要があるということです。お役に立てれば。

DECLARE @columns varchar(500)

Select @columns = STUFF(( select distinct
            '],[' + cast(Name as varchar)
              from table_name as t1
              order by '],[' + cast(Name as varchar)
              for XML path('')
              ), 1, 2, '') + ']'

DECLARE @query varchar(max)

SET @query = 'select *
             from table_name
             pivot
             (
              count(Name)
              for Name in (' +@columns+ ')
             )as pvt'

execute(@query)
于 2013-01-25T16:49:24.683 に答える