首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >有什么办法可以让这个linq2sql更干吗?

有什么办法可以让这个linq2sql更干吗?
EN

Stack Overflow用户
提问于 2022-11-21 14:40:13
回答 1查看 19关注 0票数 0

我想删除这段代码中的重复内容。是否可以编写一个函数来清除任何具有指定字符串(或字符)数组的表nvarchar列?该查询将在最后以ef核执行。

我尝试了VS2022重构工具来提取方法,但它提取了整个Where()。我想“构建”替换链。这有可能吗?

代码语言:javascript
复制
var request = GetRequestValuesFromApi();

var query = _context.Persons.AsQueryable();

if (!string.IsNullOrWhiteSpace(request.Firstname))
{
    string firstname = request.Firstname.Replace("-", "").Replace(" ", "").Replace("’", "").Replace("'", "");
    query = query.Where(x => EF.Functions.Collate(x.Firstname!, "binary_ai").Replace("-", "").Replace(" ", "").Replace("’", "").Replace("'", "").Contains(firstname));
}

if (!string.IsNullOrWhiteSpace(request.Lastname))
{
    string lastname = request.Lastname.Replace("-", "").Replace(" ", "").Replace("’", "").Replace("'", "");
    query = query.Where(x => EF.Functions.Collate(x.Lastname!, "binary_ai").Replace("-", "").Replace(" ", "").Replace("’", "").Replace("'", "").Contains(lastname));
}

// ...

var results = query.ToList();
EN

回答 1

Stack Overflow用户

发布于 2022-11-21 21:11:28

如果您愿意使用LINQKit,您可以在查询中嵌入Expression变量,并在执行查询之前将它们展开:

代码语言:javascript
复制
var query = _context.Persons.AsQueryable().AsExpandable();

Expression<Func<string,string>> FixNameEFn = (string name) => name.Replace("-", "").Replace(" ", "").Replace("’", "").Replace("'", "");
var FixNameFn = FixNameEFn.Compile();

if (!string.IsNullOrWhiteSpace(request.Firstname)) {
    string firstname = FixNameFn(request.Firstname);
    query = query.Where(x => FixNameEFn.Invoke(EF.Functions.Collate(x.Firstname!, "binary_ai")).Contains(firstname));
}

if (!string.IsNullOrWhiteSpace(request.Lastname)) {
    string lastname = FixNameFn(request.Lastname);
    query = query.Where(x => FixNameEFn.Invoke(EF.Functions.Collate(x.Lastname!, "binary_ai")).Contains(lastname));
}

您可以在不使用LINQKit的情况下做到这一点,但它需要将特殊操作推入自定义Where方法(例如,WhereNameContains),然后该方法构建或修改Expression<Func<>>,并在常规的Where调用中使用它。但这将允许您删除EF.Functions.Collate的重复。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74520618

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档