各位大虾!~循环输出,求重复次数。。

脑子抽筋了 2013-03-19 12:55:03

private DataTable GetData()
{
SqlDataAdapter da = new SqlDataAdapter("select count(paper_deptid),paper_deptid from papers group by paper_deptid", con);
DataSet ds = new DataSet();
da.Fill(ds, "kw");
DataTable tableInfo = new DataTable();

DataColumn dcCity = new DataColumn("City", Type.GetType("System.String"));
DataColumn dcCount = new DataColumn("Count", Type.GetType("System.String"));

tableInfo.Columns.Add(dcCity);
tableInfo.Columns.Add(dcCount);


for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
{
DataRow dr = tableInfo.NewRow();
dr["City"] = ds.Tables[0].Rows[i]["paper_deptid"].ToString();
//dr["Count"]=ds.Tables["paper_deptid"].Rows.Count;
dr["Count"] = ds.Tables[0].Rows[i]["count(paper_deptid)"].ToString();

tableInfo.Rows.Add(dr);
}
return tableInfo;
}

哪里错了呀,原本想用这个来求重复次数:ds.Tables["paper_deptid"].Rows.Count 发现不行,然后就用了group by 来求重复次数, 但是下面就不会引用这个结果了
...全文
116 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
threenewbee 2013-03-19
  • 打赏
  • 举报
回复
dept.dept_name =〉 min(dept.dept_name)
脑子抽筋了 2013-03-19
  • 打赏
  • 举报
回复
引用 1 楼 caozhy 的回复:
select count(paper_deptid) as papercount, paper_deptid from papers group by paper_deptid dr["Count"] = ds.Tables[0].Rows[i]["papercount"].ToString();
这个方法可以了,我把查询语句改成 select count(paper_deptid) as papercount,paper_deptid,dept_name from papers,dept where papers.paper_deptid=dept.dept_id group by papers.paper_deptid 提示错误:列 'dept.dept_name' 在选择列表中无效,因为该列既不包含在聚合函数中,也不包含在 GROUP BY 子句中。
md5e 2013-03-19
  • 打赏
  • 举报
回复
难道这样不行吗? dr["Count"] = ds.Tables[0].Rows[i][0].ToString();
清秋喜乐 2013-03-19
  • 打赏
  • 举报
回复
引用 4 楼 leo_changyu 的回复:
paper_deptid是字段名。 可以用ds.Tables["papers"].Rows.Count 或者ds.Tables[0].Rows.Count
抱歉,应该是ds.Tables["kw"].Rows.Count
清秋喜乐 2013-03-19
  • 打赏
  • 举报
回复
paper_deptid是字段名。 可以用ds.Tables["papers"].Rows.Count 或者ds.Tables[0].Rows.Count
天下如山 2013-03-19
  • 打赏
  • 举报
回复
引用 2 楼 Slendxyl 的回复:
"paper_deptid"又不是表名,ds.Tables["paper_deptid"].Rows.Count 当然不行了
赞同
Slendxyl 2013-03-19
  • 打赏
  • 举报
回复
"paper_deptid"又不是表名,ds.Tables["paper_deptid"].Rows.Count 当然不行了
lutaotony 2013-03-19
  • 打赏
  • 举报
回复
对呀,聚合函数就是除了聚合的列,group by 后面都要和前面的列一致。 select count(paper_deptid) as papercount,paper_deptid,dept_name from papers,dept where papers.paper_deptid=dept.dept_id group by papers.paper_deptid,dept_name
threenewbee 2013-03-19
  • 打赏
  • 举报
回复
select count(paper_deptid) as papercount, paper_deptid from papers group by paper_deptid dr["Count"] = ds.Tables[0].Rows[i]["papercount"].ToString();

62,025

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧