假设有成绩类,字段如下

//成绩类
public class Score{
    public int id{get;set;}
    //学号
    public string No{get;set;}
    //学科
    public string subject{get;set;}
    //成绩
    public string score{get;set;}
}

需要实现数据汇总,汇总要求:结果中每行只展示单一学生信息,成绩结果进行字符串拼接显示在一个字段中

实现:

//使用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}"), ",")//对分组后的结果集进行学号匹配并去重后拼接为字符串
    });

假设有数据:

主键学号学科成绩
10001语文78
20001数学79
30001英语80
40002语文60
50002数学60
60003语文55
70003数学68

 

执行后的理论结果:

000178,79,80
000260,60
000355,68

注:示例中没有处理结果集中数据排序问题,如需保证排序规则统一,需指定排序规则(在SqlFunc.Subqueryable<T>().Where()方法后增加排序方法)

点赞(0) 打赏

评论列表 共有 0 条评论

暂无评论

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部