Sat*_*tap 9 .net c# linq linq-to-entities entity-framework
我有一个场景,我只需要WHERE在必要时使用use 子句,否则我只想在没有该WHERE子句的情况下运行我的LINQ查询.
例如:
if string name ="";
var res = (from a in db.person
select new() { Name = a.FullName, DOB = a.DOB }).ToList();
Run Code Online (Sandbox Code Playgroud)
如果string name ="satya";
var res = (from a in db.person
where a.person.contains(name)
select new() { Name = a.FullName, DOB = a.DOB }).ToList();
Run Code Online (Sandbox Code Playgroud)
我知道为此我们必须分别编写单独的2个查询,但是如果不编写单独的查询,我们如何将它们组合成单个查询?
Nic*_*las 20
你可以做:
var res = (from a in db.person
where name == "" || a.person.Contains(name)
select new { Name = a.FullName, DOB = a.DOB }
).ToList();
Run Code Online (Sandbox Code Playgroud)
或者,在这里使用流畅的语法,您可以构建您的查询并在完成后执行它:
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();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5598 次 |
| 最近记录: |