多条件查询

cpp_1 2021-04-27 12:23:14
我用的是asp.net +EF

表结构
id name sex .....

前台有一个输入框,现在需要以‘空格’为分割符输入多姓名条件进行查询

var aa = from s in _context.aa
select s;

aa=aa.Where(s => s.name.Contains(searchString))


原来一个条件可以用Contains直接来查询

现在如果输入 【测试 用户 其它。。】这种多条件,怎么写这个表达式
...全文
166 8 打赏 收藏 举报
写回复
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
YBcsdn1996 2021-04-28
https://blog.csdn.net/weixin_30326515/article/details/96638752
  • 打赏
  • 举报
回复
YBcsdn1996 2021-04-28

string [] arr=split(" ");先拆解 再拼接 var ListWhere= PredicateBuilder.True<ModelClass>();
for(int i=0 ;i<arr.length;i++){
ListWhere=ListWhere.Or(s => s.name .Contains(arr[i]));


}
var aa= aa.Where(predicate).ToList();
  • 打赏
  • 举报
回复
cpp_1 2021-04-28
引用 5 楼 YBcsdn1996 的回复:
string [] arr=split(" ");先拆解 再拼接 var ListWhere= PredicateBuilder.True<ModelClass>(); for(int i=0 ;i<arr.length;i++){ ListWhere=ListWhere.Or(s => s.name .Contains(arr[i])); } var aa= aa.Where(predicate).ToList();
这个需要用FALSE才可以正确查询。
  • 打赏
  • 举报
回复
cpp_1 2021-04-27
引用 2 楼 楠小南 的回复:
EF linq 最好不要嵌套任何方法,因为他要生成SQL语句的,一旦他解析不了的,就给你全表了,这个一定要注意! 你这就用in 语句 就是了, in 语句就是 Contains string[] array = 用户输入.split(' '); var data = _context.aa.where(a=>array.Contains(a.name)).tolist();
用 string[] 不行,模糊查询以后,一条也没有了
  • 打赏
  • 举报
回复
hui1202 2021-04-27
摩拜下17年大佬
  • 打赏
  • 举报
回复
楠小南 2021-04-27
EF linq 最好不要嵌套任何方法,因为他要生成SQL语句的,一旦他解析不了的,就给你全表了,这个一定要注意! 你这就用in 语句 就是了, in 语句就是 Contains string[] array = 用户输入.split(' '); var data = _context.aa.where(a=>array.Contains(a.name)).tolist();
  • 打赏
  • 举报
回复
大然然 2021-06-23
@楠小南 你这种办法会丢失很多数据
  • 举报
回复
Hello World, 2021-04-27
可以用dapper,传列表作为参数
  • 打赏
  • 举报
回复
发帖
.NET社区

6.0w+

社区成员

.NET技术交流专区
社区管理员
  • ASP.NET
  • R小R
  • 喵叔哟
加入社区
帖子事件
创建了帖子
2021-04-27 12:23
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。