加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 如何使用LINQ 创建条件where子句

发布时间:2020-12-15 04:20:12 所属栏目:百科 来源:网络整理
导读:参见英文答案 Linq: adding conditions to the where clause conditionally6个 我有一个场景,我只想在必要时使用WHERE子句,否则我只想运行没有WHERE子句的LINQ查询. 例如: if string name =“”; var res = (from a in db.person select new() { Name = a.F
参见英文答案 > Linq: adding conditions to the where clause conditionally6个
我有一个场景,我只想在必要时使用WHERE子句,否则我只想运行没有WHERE子句的LINQ查询.

例如:

if string name =“”;

var res = (from a in db.person 
           select new() { Name = a.FullName,DOB = a.DOB }).ToList();

如果string name =“satya”;

var res = (from a in db.person
           where a.person.contains(name)
           select new() { Name = a.FullName,DOB = a.DOB }).ToList();

我知道为此我们必须分别编写单独的2个查询,但是如果不编写单独的查询,我们如何将它们组合成单个查询?

解决方法

你可以做:
var res = (from a in db.person
           where name == "" || a.person.Contains(name)
           select new { Name = a.FullName,DOB = a.DOB }
          ).ToList();

或者,在这里使用流畅的语法,您可以构建查询并在完成后执行它:

var query = db.person.AsQueryable();

if(!String.IsNullOrEmpty(name)) {
    query = query.Where(a => a.person.Contains(name));
}

var result = query.Select(s => new { Name = s.FullName,DOB = s.DOB })
                  .ToList();

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读