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

相关推荐
聪明的笨猪猪14 小时前
Java Redis “缓存设计”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
FIavor.14 小时前
我发送给Apifox是http://localhost:9002/goods/getByUserName?name=张三 为什么会是500哪里错了?
java·服务器·网络协议·http
ID_1800790547314 小时前
京东获取整站实时商品详情数据|商品标题|数据分析提取教程
java·开发语言
微露清风15 小时前
系统性学习C++-第五讲-内存管理
java·c++·学习
计算机毕业设计木哥15 小时前
计算机毕业设计选题推荐:基于SpringBoot和Vue的快递物流仓库管理系统【源码+文档+调试】
java·vue.js·spring boot·后端·课程设计
qiuiuiu41315 小时前
正点原子RK3568学习日志-编译第一个驱动程序helloworld
linux·c语言·开发语言·单片机
2351615 小时前
【LeetCode】146. LRU 缓存
java·后端·算法·leetcode·链表·缓存·职场和发展
聪明的笨猪猪15 小时前
Java Redis “运维”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
FIavor.15 小时前
怎么办这是Apifox里执行http://localhost:9002/goods/getByUserName?name=“张三“为什么我改了还是500?
java·网络·网络协议·http
编程饭碗15 小时前
【Java集合】
java