我想删除这段代码中的重复内容。是否可以编写一个函数来清除任何具有指定字符串(或字符)数组的表nvarchar列?该查询将在最后以ef核执行。
我尝试了VS2022重构工具来提取方法,但它提取了整个Where()。我想“构建”替换链。这有可能吗?
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();发布于 2022-11-21 21:11:28
如果您愿意使用LINQKit,您可以在查询中嵌入Expression变量,并在执行查询之前将它们展开:
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的重复。
https://stackoverflow.com/questions/74520618
复制相似问题