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

前端之家收集整理的这篇文章主要介绍了c# – 如何使用LINQ 创建条件where子句前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
参见英文答案 > Linq: adding conditions to the where clause conditionally6个
我有一个场景,我只想在必要时使用WHERE子句,否则我只想运行没有WHERE子句的LINQ查询.

例如:

if string name =“”;

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

如果string name =“satya”;

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

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

解决方法

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

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

  1. var query = db.person.AsQueryable();
  2.  
  3. if(!String.IsNullOrEmpty(name)) {
  4. query = query.Where(a => a.person.Contains(name));
  5. }
  6.  
  7. var result = query.Select(s => new { Name = s.FullName,DOB = s.DOB })
  8. .ToList();

猜你在找的C#相关文章