假设有成绩类,字段如下
cs
//成绩类
public class Score{
public int id{get;set;}
//学号
public string No{get;set;}
//学科
public string subject{get;set;}
//成绩
public string score{get;set;}
}
需要实现数据汇总,汇总要求:结果中每行只展示单一学生信息,成绩结果进行字符串拼接显示在一个字段中
实现:
cs
//使用sqlsugar
db.Queryable<Score>()
.GroupBy(a => a.No)
.Select<Score>(a => new ShopdetailEntity()
{
No= a.No,
score= SqlFunc.Subqueryable<Score>().Where(z => z.No== a.No)
.SelectStringJoin(z => SqlFunc.MappingColumn<string>($"distinct {a.score}"), ",")//对分组后的结果集进行学号匹配并去重后拼接为字符串
});
假设有数据:
|----|------|----|----|
| 主键 | 学号 | 学科 | 成绩 |
| 1 | 0001 | 语文 | 78 |
| 2 | 0001 | 数学 | 79 |
| 3 | 0001 | 英语 | 80 |
| 4 | 0002 | 语文 | 60 |
| 5 | 0002 | 数学 | 60 |
| 6 | 0003 | 语文 | 55 |
| 7 | 0003 | 数学 | 68 |
执行后的理论结果:
|------|----------|
| 0001 | 78,79,80 |
| 0002 | 60,60 |
| 0003 | 55,68 |
注:示例中没有处理结果集中数据排序问题,如需保证排序规则统一,需指定排序规则(在SqlFunc.Subqueryable<T>().Where()方法后增加排序方法)