多条件查询

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直接来查询

现在如果输入 【测试 用户 其它。。】这种多条件,怎么写这个表达式
...全文
192 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
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,传列表作为参数

62,243

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

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

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

试试用AI创作助手写篇文章吧