Asp.Net上带有相关列的DataTable数据列表

时间:2016-08-26 05:37:42

标签: c# asp.net sql-server linq foreach

我在SQL中有以下表格:

 PARENT_CODE   CHILD_CODE   ATTRIBUTE_NAME  ATTRIBUTE_DESCRIPT R_YEAR    
    ------------- ------------ --------------  ------------------ -----------
    1             001           ATT1            Description1       2016
    1             001           ATT2            Description2       2016
    1             001           ATT3            Description3       2016
    1             001           ATT4            Description4       2016
    1             001           ATT5            Description5       2016
    1             001           ATT6            Description6       2016
    1             002           ATT1            Description1       2016
    1             002           ATT2            Description2       2016
    1             002           ATT3            Description3       2016
    1             002           ATT4            Description4       2016
    2             003           ATT1            Description1       2016
    2             003           ATT2            Description2       2016
    2             003           ATT3            Description3       2016
    2             003           ATT4            Description4       2016

如何以下面的格式显示输出?

 1 - 001 :
  ATT1 : Description1  
  ATT2 : Description2  
  ATT3 : Description3  
  ATT4 : Description4  
  ATT5 : Description5  
  ATT6 : Description6
1 - 002 :    
  ATT1 : Description1  
  ATT2 : Description2  
  ATT3 : Description3  
  ATT4 : Description4   
2 - 003 :    
  ATT1 : Description1  
  ATT1 : Description2  
  ATT1 : Description3  
  ATT1 : Description4  

我知道我们可以使用LinQ或foreach循环来获得结果,但我不知道如何继续。

在我的代码下面:

string[] seledItems = ConvertLib.ToStr(Request.Form["sel_items[]"], string.Empty).Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries);

string GetQUeryStr = string.Format(@"SELECT PARENT_CODE,CHILD_CODE,ATTRIBUTE_NAME,ATTRIBUTE_DESCRIPT,R_YEAR FROM JOBPATTERN
                                     WHERE R_YEAR='{0}' AND PARENT_CODE IN ({1})", ddlYears.SelectedValue, string.Join(",", seledItems.Select(q => string.Format("'{0}'", q)).ToArray()));

using (SqlConnection conn = new SqlConnection(connectionString))
{
    using (SqlCommand cmd = new SqlCommand(GetQUeryStr, conn))
    {

        DataTable dt = new DataTable();
        conn.Open();
        cmd.ExecuteNonQuery();
        conn.Close();
        SqlDataAdapter da = new SqlDataAdapter(cmd);
        da.Fill(dt);

        foreach(var item in list)
        {
         // then how can i  write this part
        }
     }
}

我在上面添加了我的代码以供参考。

1 个答案:

答案 0 :(得分:0)

根据您希望我理解的输入格式,您希望按多列进行分组,并为每个键提供其下的匹配项列表。

使用linq查询语法:

var result = (from item in dt
              group new { item.ATTRIBUTE_NAME, item.ATTRIBUTE_DESCRIPT }
              by new { item.PARENT_CODE, item.CHILD_COD } into g
              select new 
              {
                  g.Key,
                  Items = g.ToList();
              });

在方法语法中:

var result = dt.GroupBy(item => new { item.ATTRIBUTE_NAME, item.ATTRIBUTE_DESCRIPT }
                        (key, group) => new 
                        { 
                            key, 
                            Items = group.Select(item => new { item.PARENT_CODE, item.CHILD_COD }).ToList()
                        });

最后但并非最不重要 - 请不要使用字符串连接来构建您的SQL查询。它易受SQL注入的影响。请改用参数化查询