【.net core】【sqlsugar】字符串拼接+内容去重

假设有成绩类,字段如下

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()方法后增加排序方法)

相关推荐
WooaiJava2 分钟前
流式TTS音频播放项目 - 面试问答(后端)
java·开发语言
奥升新能源平台3 分钟前
奥升充电|充电站用户分层分析与精细化运营策略研究
java·大数据·能源
新缸中之脑11 分钟前
开发AI代理必备的8个Python 库
开发语言·人工智能·python
暴走十八步14 分钟前
PHP+vscode开启调试debug
开发语言·vscode·php
梵得儿SHI16 分钟前
(第十篇)Spring AI 核心技术攻坚全梳理:企业级能力矩阵 + 四大技术栈攻坚 + 性能优化 Checklist + 实战项目预告
java·人工智能·spring·rag·企业级ai应用·springai技术体系·多模态和安全防护
一路向北⁢17 分钟前
Spring Boot 3 整合 SSE (Server-Sent Events) 企业级最佳实践(三)
java·spring boot·后端·sse
郝学胜-神的一滴18 分钟前
Python 列表 vs 数组:深入解析与最佳选择指南
开发语言·python·程序人生
杜子不疼.18 分钟前
基于ATVC模板库的Ascend C Vector算子快速开发指南
c语言·开发语言·mfc
MSTcheng.20 分钟前
【C++】C++11新特性(三)
开发语言·c++·c++11
learning-striving21 分钟前
kali连不上网解决方法
linux·开发语言·网络·php·kali