首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C# SQL查询-尝试使用sum(weekly_slot) FROM group by

C# SQL查询-尝试使用sum(weekly_slot) FROM group by
EN

Stack Overflow用户
提问于 2017-05-22 10:40:34
回答 2查看 51关注 0票数 0

我正在尝试根据GroupOdd数据库表中的Teacher_Nameweekly_slot求和,但是我得到了所有行的10个值。如果能纠正我,我将不胜感激。除此之外,如何更新GroupOdd dbtable以首先根据较大的sum_weekly_slot进行排序?

谢谢。

代码语言:javascript
复制
cmd2 = new SQLiteCommand();
cmd2 = dbConnect.CreateCommand();
//cmd2.CommandText = "DELETE FROM GroupOdd";
//cmd2.ExecuteNonQuery();
cmd2.CommandText = "SELECT Sum(Weekly_Slot) AS Sum_Weekly_Slot FROM GroupOdd group by Teacher_Name";
DataTable dt2 = new DataTable();
SQLiteDataAdapter da2 = new SQLiteDataAdapter(cmd2);
da2.Fill(dt2);
foreach (DataRow dr2 in dt2.Rows)
{
    //cmd.CommandText = "INSERT INTO GroupOdd (Teacher_Name, Standard, Subject, Weekly_Slot, Balance_Slot) VALUES (@Teacher_Name, @Standard, @Subject, @Weekly_Slot, @Balance_Slot)";
    cmd2.CommandText = "UPDATE GroupOdd SET Sum_Weekly_Slot = @Sum_Weekly_Slot";
    //cmd2.Parameters.AddWithValue("@Sum_Weekly_Slot", dr2["Sum(Weekly_Slot)"].ToString());
    cmd2.Parameters.AddWithValue("@Sum_Weekly_Slot", dr2["Sum_Weekly_Slot"].ToString());
    cmd2.ExecuteNonQuery();
}
EN

回答 2

Stack Overflow用户

发布于 2017-05-22 11:04:27

您只需要一个带有MAX聚合函数的GROUP BY子句:

代码语言:javascript
复制
SELECT id, MAX(rev)
FROM YourTable
GROUP BY id

而不是相应地更新它。

如果

代码语言:javascript
复制
Sum(Weekly_Slot);

不是你想要的

试一试

代码语言:javascript
复制
Count(Weekly_Slot)
票数 0
EN

Stack Overflow用户

发布于 2017-05-22 11:49:14

代码语言:javascript
复制
SELECT Teacher_Name, Sum(Weekly_Slot) AS Sum_Weekly_Slot FROM GroupOdd 
group by Teacher_Name order by Sum(Weekly_Slot) desc

检查Teacher_Names是否唯一,否则请尝试使用教师的Id (TeacherId)。order by Sum(Weekly_Slot) desc应该首先按最大值对表排序。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44103867

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档