Linq 中的动态 Where 查询如何实现 OR ?

Triumph 2014-05-08 09:10:57
Info 表中有两个字段:N 和 V,都是字符串类型,现要查询:N 等于 n1 并且 V 包含 v1,或者N等于 n2 并且 V 包含 v2,或者 N 等于 n2 并且 V 包含 v3,写 linq 如下:

from t in info where (t.N = "n1" And t.V.Contains("v1")) Or (t.N = "n2" And t.V.Contains("v2")) Or (t.N = "n3" And t.V.Contains("v3"))

这个运行正确。

但实际上查询的关键字是动态的,数量是未知的,于是建立一个 Dictionary(Of String, String):

Dim keyList As New Dictionary(Of String, String)
keyList.Add("n1","v1")
keyList.Add("n2","v2")
keyList.Add("n3","v3")
....
....

dim _q = From t In info
For Each key As String In keyList.Keys
dim _v As String = keyList(key)
_q = _q.Where(Function (x) x.N = key And x.V.Contains(_v))
Next

这样最终的查询条件就全都是 And 而不是前一个的OR b ,结果当然不正确。

请教各位如何这种情况如何实现?
...全文
696 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
Triumph 2014-05-10
  • 打赏
  • 举报
回复
romanchaos:后一个管用,而且思路很好,让我豁然开朗。非常感谢!!!
romanchaos 2014-05-09
  • 打赏
  • 举报
回复
修改一下 dim _q = From t In info dim _p = IQuaeryable<info> For Each key As String In keyList.Keys dim _v As String = keyList(key) _p = _p.Union(_q.Where(条件Next)) Next
romanchaos 2014-05-09
  • 打赏
  • 举报
回复
dim _q = From t In info Where 条件1 For Each key As String In keyList.Keys dim _v As String = keyList(key) _q = _q.Union(_q.Where(条件Next)) Next
Triumph 2014-05-09
  • 打赏
  • 举报
回复
结果不正确呀?连单个的都查询不出来了
threenewbee 2014-05-08
  • 打赏
  • 举报
回复
_q = _q..Union(_q.Where(Function (x) 下一个条件))
走进Linq--Linq横空出世篇 某日编程大师云游到某处,见一刚毕业不久学过两天C#和两天SQL的coder在那里发牢骚,为啥我要写这么多for,这么多if才能查询出我需要的数据,为啥我不能像SQL那样,发送一条命令告诉数据库我需要啥样的数据,它就给我返回来。 编程大师如是说:傻小子,像SQL那叫第四代编程语言,常存在于象牙塔和研究所里面的学究语言,还有个高雅的名字:函数编程。它只需要你告诉它要什么,而不需要告诉它怎么做。而你使用的C#语言属于命令式编程,你必须像发送命令一样一步步的告诉你的机器怎么做。 发牢骚的coder回了一句:不懂,我只是想不通,数据库能做这样的处理,为啥C#这么牛的语言不能呢。编程大师心里想着:这是不可能的事情,因为C#它是强类型语言,)*&)(&)*)()*&%&%&^(后面省去200字)。 天色还未晚,编程大师就急匆匆的回家了,他心里一直记着那位发牢骚的coder的话:为什么不能,为什么不能。 晚上,编程大师做了一个梦,一个奇怪的梦,他的师傅“白眉”只说了三个字母:DSL。 编程大师想着,DSL,领域专用语言,师傅要对我说什么呢,难道和今天我遇见的事有关? 上面这段文字是一段调侃,调节一下气氛,呵呵。 我觉得Linq就是一种DSL,在C#等常规语言上抽象起来的,面向数据处理领域的特定“语言”,当然,它的根基还是这些常规语言。 select,from,where,group等关键字本来只是在SQL里出现,现在把它们引入到C#这些常规编程语言。 那C#等是如何做到的呢?是在CLR底层支持的么?不是。既然“编译器”可以将C#编译成MSIL,那为什么编译不能干更多一点事情?将这些为了领域编程而出现关键字编译成原始语法。

8,493

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 LINQ
社区管理员
  • LINQ
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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