Entity Framework in not in

w23647460 2013-01-09 09:24:23
.Get().Where(p => new int[] { 74169, 74170, 74171 }.Contains(p.nID)).ToList();

这样是有效的,但是换成

int[] ids = new int[]{ 74169, 74170, 74171 };
.Get().Where(p => new int[] { 74169, 74170, 74171 }.Contains(p.nID)).ToList();

这样就没有效果了



求教~
...全文
165 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
w23647460 2013-01-10
  • 打赏
  • 举报
回复
sorry 自己写错代码了 方法2 是对的 有效
w23647460 2013-01-10
  • 打赏
  • 举报
回复
1、 .Get().Where(p => new int[] { 74169, 74170, 74171 }.Contains(p.nID)).ToList(); 这样是有效的,但是换成 2、 int[] ids = new int[]{ 74169, 74170, 74171 }; .Get().Where(p => ids.Contains(p.nID)).ToList(); 不好意思发急了,没检查 1 转换执行SQL时是 nID in (74169, 74170, 74171 ) 2 转换执行SQL时是 nID in (74169, 74169, 74169 ) 问题 因为这个数组不是固定的 但是用方法2 又不能包含所以的ID
threenewbee 2013-01-09
  • 打赏
  • 举报
回复
上下有什么区别?

110,533

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

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