指定的 LINQ 表达式包含对与不同上下文关联的查询的引用

 var modules= (from m in account.RolesPermission where m.RoleID == ut select m.ModuleID).ToList();
 var acticles = from a in ac.News
                where
                modules.Contains(a.DeliveryModuleID)                             
                && a.IsValid == "1"
                && a.StatusType == "1"
                && a.ProcessStatus == "1"
                select a;
上面的写法是可以进行正常查询的。
要是写到一起就不可以了,例如:
<pre name="code" class="csharp">var acticles = from a in ac.News
                where            <pre name="code" class="csharp">(from m in account.RolesPermission where m.RoleID == ut select m.ModuleID)<pre name="code" class="csharp">.Contains(a.DeliveryModuleID)  <span style="font-family: Arial, Helvetica, sans-serif;">                       </span>
 && a.IsValid == "1" && a.StatusType == "1" && a.ProcessStatus == "1" select a; 
 这样会报出错 
 
“指定的 LINQ 表达式包含对与不同上下文关联的查询的引用”
<span style="font-family: Arial; font-size: 14px; line-height: 26px;">上面的查询需要访问两个上下文。解决方法是分两次查询。并且使用.ToList(),将数据读到内存</span>
<span style="font-family: Arial; font-size: 14px; line-height: 26px;">报错的原因是在涉及到内存中的对象与EF里的对象混合查询时,内存中的对象要是基元类型。</span>
<span style="font-family:Arial;"><span style="font-size: 14px; line-height: 26px;">值得一说的是如果是在同一个对象里面进行混合查询时允许的,例如:</span></span>
<span style="font-family:Arial;"><span style="font-size: 14px; line-height: 26px;"> var Module = from p1 in ac.PageModule
                             where
                             !(
                               (from p2 in ac.PageModule
                                select p2.ParenModuleID).Contains(p1.ModuleID)
                              )
                             select new
                             {
                                 ModuleID = p1.ModuleID,
                                 ModuleName = p1.ModuleName
                             };</span></span>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值