由于Linq查询主要是强类型查询,所以很难做到像sql语句一样,在执行前可以动态拼接。
不过通过方法或者集合方式也可以实现一定的动态化。
1.动态的or操作。可以简单的使用list创建搜索集合。
#region 搜索 List<string> list = new List<string>(); list.Add("str1"); list.Add("str2"); list.Add("str3"); var v = from A in Models from B in list where A.数据.Contains(B) select A; #endregion
或者
#region 搜索 List<string> list = new List<string>(); list.Add("str1"); list.Add("str2"); list.Add("str3"); var result = from o in Models where list.All(s => o.数据.ToLower().Contains(s.ToLower()) #endregion
2.动态的and操作。可以简单的使用list创建搜索集合。
当然不写方法直接循环执行也可以。
#region 搜索 List<string> list = new List<string>(); list.Add("str1"); list.Add("str2"); list.Add("str3"); List<string> Models = new List<string>(); foreach (string l in list) { Models = GetSearch(Models, l); } #endregion List<string> GetSearch(List<string> ss, string str) { var v = from A in ss where A == str select A; List<string> Models = v.ToList(); return Models; }
标签:C#,list,List,Linq,Models,Add,搜索,new,动态化 From: https://www.cnblogs.com/cuihongyu3503319/p/17149087.html