登录
注册
开源
企业版
高校版
搜索
帮助中心
使用条款
关于我们
开源
企业版
高校版
私有云
模力方舟
AI 队友
登录
注册
轻量养虾,开箱即用!低 Token + 稳定算力,Gitee & 模力方舟联合出品的 PocketClaw 正式开售!点击了解详情~
代码拉取完成,页面将自动刷新
开源项目
>
WEB应用开发
>
Web开发框架
&&
捐赠
捐赠前请先登录
取消
前往登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
Watch
不关注
关注所有动态
仅关注版本发行动态
关注但不提醒动态
9.9K
Star
14.5K
Fork
4.2K
GVP
dotNET China
/
Furion
代码
Issues
0
Pull Requests
0
统计
流水线
服务
质量分析
Jenkins for Gitee
腾讯云托管
腾讯云 Serverless
悬镜安全
阿里云 SAE
Codeblitz
SBOM
开发画像分析
我知道了,不再自动展开
434
新增拓展方法,使用表达式树实现动态构建Lambda
已关闭
用户已删除:master
dotNET China:master
wosperry
创建于 2021-10-19 00:10
克隆/下载
HTTPS
SSH
复制
下载 Email Patch
下载 Diff 文件
### 相关的 Issue 无 ### 原因(目的、解决的问题等) 目的:减少IQueryable根据不确定个条件进行筛选的代码量 解决问题:根据前端提供的不确定个条件进行筛选的时候,后端要写判断与Where表达式筛选数据。当允许前端筛选的字段变多时,代码会出现大片`if`和`Where`(或者是`WhereIf`),这种代码逻辑一样,重复率高。意在减少这类不美观的代码。 ### 描述(做了什么,变更了什么) - 对 `IQueryable` 拓展了 `BuildLambda`,动态构建表达式(结果格式:`t=>t.Name.Contains(input.Name) && t.Age>=18` - 对 `IEnumerable` 拓展了 `BuildWhere`,原因是只有上方拓展时,`IEnumerable` 集合使用的话需要像下方这样调用 ``` csharp // 拓展前 public async Task<Student> GetListAsync(GetListParameter input) { var query = _repository.AsQueryable(); if(!string.IsNullOrWhiteSpace(input.Name)) query = query.Where(t=>t.Name.Contains(input.Name)); if(input.Age.HasValue) query = query.Where(t=>t.Age == input.Age); // ... // 省略 // ...; return await query.ToListAsync(); } ``` ``` csharp // 拓展 IQueryable 后 public async Task<Student> GetListAsync(GetListParameter input) { return await _repository.BuildWhere(input).ToListAsync();// 手撸,不确定有没有ToListAsync } ``` ``` csharp // 集合使用: IEnumerable students = new List<Student>(){.....}; var queryParam = new StudentQueryParam{Name="王", Code=null, Age=null, Gender=GenderEnum.Male,}; // 未拓展 BuildWhere var query = students.AsQueryable(); var result = query.Where(query.BuildLambda(input)); // 拓展 BuildWhere 后 var result = students.BuildWhere(input); ``` ### 测试用例(新增、改动、可能影响的功能) - 改动:仅拓展新名字的方法,与原有功能无关 - 影响:无影响(已检查代码,不存在同名方法) - 测试用例预览(2/7): ``` csharp /// <summary> /// 测试:数值等于 /// </summary> [Fact] public void TestValueEqual() { // 最简单写法,后面的测试都打印表达式,稍微长点 var input = new StudentListQueryParameter { Age = 18 }; var result = students.BuildWhere(input); Output.WriteLine("最简单写法,其他的测试都打印表达式,代码多了两行"); Output.WriteLine("数值相等"); Output.WriteLine("结果:" + JsonConvert.SerializeObject(result)); } /** Furion.UnitTests.BuildWhereExtenstionTest.TestValueEqual 源: BuildWhereExtensionTest.cs 行 63 持续时间: 16 毫秒 标准输出: 最简单写法,其他的测试都打印表达式,代码多了两行 数值相等 结果:[{"Name":"李四","Age":18,"Code":"A002"},{"Name":"张四","Age":18,"Code":"B001"},{"Name":"李六","Age":18,"Code":"C002"}] */ ``` ``` csharp /// <summary> /// 测试:多个条件 /// </summary> [Fact] public void TestMultiFilter() { var input = new StudentListQueryParameter { Name = "张", AgeLargerEqualThen=18 }; var query = students.AsQueryable(); var lambda = query.BuildLambda(input); var result = query.Where(lambda); Output.WriteLine("表达式:" + lambda); Output.WriteLine("结果:" + JsonConvert.SerializeObject(result)); } /** Furion.UnitTests.BuildWhereExtenstionTest.TestMultiFilter 源: BuildWhereExtensionTest.cs 行 143 持续时间: 16 毫秒 标准输出: 表达式:t => (((True AndAlso True) AndAlso t.Name.Contains("张", CurrentCulture)) AndAlso (t.Age >= Convert(18, Nullable`1))) 结果:[{"Name":"张三","Age":25,"Code":"A001"},{"Name":"张四","Age":18,"Code":"B001"},{"Name":"张五","Age":22,"Code":"C001"}] */ ``` - 实体与参数类 ``` csharp /// <summary> /// 实体类 /// </summary> public class Student { public string Name { get; set; } public string Code { get; set; } public int? Age { get; set; } } /// <summary> /// 请求参数类 /// </summary> public class StudentListQueryParameter { // 参数属性名与集合实体类型属性名不一致时,通过特性参数指定 [WhereLike] public string Name { get; set; } [WhereLike("Code")] public string CodeLike { get; set; } [WhereEqual] public string Code { get; set; } //不提供参数时,与属性一致 [WhereEqual("Age")] public int? Age { get; set; } [WhereLarger("Age")] public int? AgeLargerThen { get; set; } [WhereLargerEqual("Age")] public int? AgeLargerEqualThen { get; set; } } ```
此 Pull Request 需要通过一些审核项
类型
指派人员
状态
审查
百小僧
进行中
(0/1人)
测试
百小僧
进行中
(0/1人)
怎样手动合并此 Pull Request
git checkout master
git pull https://gitee.com/dotnetchina/Furion.git master
git push origin master
评论
7
提交
6
文件
5
检查
代码问题
0
批量操作
展开设置
折叠设置
审查
Code Owner
审查人员
dotNET China
chinadotnet
百小僧
monksoul
诺墨
normalcoder
未设置
最少人数
1
测试
dotNET China
chinadotnet
百小僧
monksoul
诺墨
normalcoder
未设置
最少人数
1
优先级
不指定
严重
主要
次要
不重要
标签
标签管理
奇思妙想
新功能
关联 Issue
未关联
里程碑
未关联里程碑
v4.7.9
v4.8.0
v4.8.1
v4.8.2
v4.8.3
v4.8.4
v4.8.5
v4.8.6
v4.8.7
v4.8.8
v4.9.0
参与者
(2)
C#
1
https://gitee.com/dotnetchina/Furion.git
git@gitee.com:dotnetchina/Furion.git
dotnetchina
Furion
Furion
点此查找更多帮助
搜索帮助
Git 命令在线学习
如何在 Gitee 导入 GitHub 仓库
Git 仓库基础操作
企业版和社区版功能对比
SSH 公钥设置
如何处理代码冲突
仓库体积过大,如何减小?
如何找回被删除的仓库数据
Gitee 产品配额说明
GitHub仓库快速导入Gitee及同步更新
什么是 Release(发行版)
将 PHP 项目自动发布到 packagist.org
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册