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 回答