Linq If Statement

use*_*433 7 linq linq-to-entities

我如何在linq中向实体写这样的东西

sb.Append(" WHERE question.question_isdeleted = 0");
    if (catid != 0)
        sb.AppendFormat(" AND (CatID IN ({0}))", catsSTR);
    if(!string.IsNullOrEmpty(AuthorID))
        sb.Append(" AND (question_ownerid = @id)");
Run Code Online (Sandbox Code Playgroud)

我想我只需要在linq中为实体写一个if条件的语法

Jon*_*eet 14

我会在这里使用点符号:

var query = questions.Where(q => !q.IsDeleted);

if (catId != 0)
{
    query = query.Where(q => cats.Contains(q.CatID));
}
if (authorId != 0)
{
    query = query.Where(q => q.OwnerId == authorId);
}
Run Code Online (Sandbox Code Playgroud)

您可以编写自己的扩展方法来更简单地执行此操作:

public static IQueryable<T> OptionalWhere<T>(
    this IQueryable<T> source,
    bool condition, 
    Expression<Func<T,bool>> predicate)
{
    return condition ? source.Where(predicate) : source;
}
Run Code Online (Sandbox Code Playgroud)

然后你可以写:

var query = questions.Where(q => !q.IsDeleted);
                     .OptionalWhere(catId != 0, q => cats.Contains(q.CatID))
                     .OptionalWhere(authorId != 0, q => q.OwnerId == authorId);
Run Code Online (Sandbox Code Playgroud)