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

相关推荐
qq_12498707536 小时前
基于小程序中医食谱推荐系统的设计(源码+论文+部署+安装)
java·spring boot·后端·微信小程序·小程序·毕业设计·计算机毕业设计
Coder_Boy_6 小时前
基于SpringAI的在线考试系统-阅卷评分模块时序图
java·人工智能·spring boot
linweidong7 小时前
C++大型系统中如何组织头文件和依赖树?
java·c++·架构
橘子师兄7 小时前
C++AI大模型接入SDK—环境搭建
开发语言·c++·人工智能
lkbhua莱克瓦247 小时前
JavaScript核心语法
开发语言·前端·javascript·笔记·html·ecmascript·javaweb
bubiyoushang8887 小时前
基于MATLAB的近红外光谱与PLS方法测定药片有效成分含量的实现
开发语言·matlab
鹿角片ljp7 小时前
力扣14.最长公共前缀-纵向扫描法
java·算法·leetcode
weixin_433179337 小时前
Hangman 猜字游戏使用列表List实现
开发语言·python
pengweizhong7 小时前
Dynamic‑SQL2 查询篇:MyBatis 增强利器,让 SQL 像写 Java 一样丝滑
java·sql·教程
Remember_9937 小时前
【数据结构】深入理解优先级队列与堆:从原理到应用
java·数据结构·算法·spring·leetcode·maven·哈希算法