我在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
}
}
}
我在上面添加了我的代码以供参考。
答案 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注入的影响。请改用参数化查询