gpt4 book ai didi

c# - PredicateBuilder:OR 条件嵌套在 .And() 中

转载 作者:太空宇宙 更新时间:2023-11-03 22:56:10 25 4
gpt4 key购买 nike

我正在使用 PredicateBuilder 构建针对 Umbraco 节点列表的查询以过滤搜索结果。我通过 QueryString 将搜索到的 ID 值作为字符串传递过来,然后我将其与列表中每个 Umbraco 节点上的字符串字段进行比较以获得匹配项。

目前,代码对目标字段进行匹配,因为查询字符串中有一个值可以正常工作。我需要在我的 .And() 中添加一个条件,如果该字段有值,它会尝试将 QS 与字段 String 匹配,但如果该字段没有值,那么它也应该匹配该值。

    if (!string.IsNullOrEmpty(qsId))
{
predicate = predicate.And(i =>
Regex.IsMatch(i.GetProperty("makeTag").Value.ToString(), "\\b" +
qsId + "\\b"));
}

我尝试了以下方法,但似乎无法正常工作:

    if (!string.IsNullOrEmpty(qsId))
{
predicate = predicate.And(i =>
Regex.IsMatch(i.GetProperty("makeTag").Value.ToString(), "\\b" +
qsId + "\\b") ||
string.IsNullOrEmpty(i.GetProperty("makeTag")).Value.ToString());
}

关于我做错了什么或者可能有更好的方法来解决这个问题有什么想法吗?

最佳答案

对于嵌套或在 and 中,您可以:

首先创建 or,然后创建 or:

if (!string.IsNullOrEmpty(qsId))
{
// default false
var inner = PredicateBuilder.False<Product>();

// first or
inner = inner.Or (i =>
Regex.IsMatch(i.GetProperty("makeTag").Value.ToString(), "\\b" +
qsId + "\\b");

// second or
inner = inner.Or (i =>
string.IsNullOrEmpty(i.GetProperty("makeTag")).Value.ToString());


predicate = predicate.And(inner);
}

下面是我原来的回答,没有relaize需要嵌套或者in and


原始答案

如果我对您的理解正确,您正在尝试实现(硬编码时):

Where(i => 
Regex.IsMatch(i.GetProperty("makeTag").Value.ToString(), "\\b" +
qsId + "\\b" || string.IsNullOrEmpty(i.GetProperty("makeTag")).Value.ToString())

如果是这样,那么使用谓词生成器,它应该这样做:

if (!string.IsNullOrEmpty(qsId))
{

// default false
var predicate = PredicateBuilder.False<Product>();

// first or
predicate = predicate.Or (i =>
Regex.IsMatch(i.GetProperty("makeTag").Value.ToString(), "\\b" +
qsId + "\\b");

// second or
predicate = predicate.Or (i =>
string.IsNullOrEmpty(i.GetProperty("makeTag")).Value.ToString());
}

谓词生成器的更多示例,查看:http://www.albahari.com/nutshell/predicatebuilder.aspx

关于c# - PredicateBuilder:OR 条件嵌套在 .And() 中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45268997/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com