7

我有一个 linq 查询。我从收集的表单中有一堆参数,我需要根据用户正在搜索的字段进行过滤。

IQueyable<Users> user = from user in edmxObject.Users
where user.FirstName.Contains(model.FirstName ?? user.FirstName)
&& user.UserName.Contains(model.UserName ?? user.UserName)

我还有一些非字符串字段过滤器需要过滤,包括 long 和 boolean。如果用户没有选择任何东西,它们可能是空值。如何将它们包含在查询中。

4

2 回答 2

16

这是 LINQ 如此强大的最佳示例之一 - 延迟执行。您可以在不同的阶段构建查询,只有当查询最终执行或解决时,才会生成 SQL 语句:

var query = edmxObject.Users.AsQueryable<Users>();

if (! String.IsNullOrEmpty(model.FirstName)) {
    query = from user in query
            where user.FirstName.Contains(model.FirstName)
            select user;
}
if (! String.IsNullOrEmpty(model.UserName) {
    query = from user in query
            where user.UserName.Contains(model.UserName)
            select user;
}

// this will cause the query to execute get the materialized results
var result = query.ToList();
于 2012-04-05T15:02:21.440 回答
5

如果查询不包含特定字段,则根本不需要将其包含在 where 子句中:

IQueyable<Users> user = from user in edmxObject.Users;

if (model.FirstName != null) 
    users = users.Where(user => user.FirstName.Contains(model.FirstName)

if (/* age is searched for */) 
    users = users.Where(user => user.Age == model.Age);

您可以通过这种方式有条件地嵌套谓词,以确保您只有真正需要的条件。

于 2012-04-05T15:04:15.340 回答