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

来源:互联网 发布:双色球作假视频 知乎 编辑:程序博客网 时间:2024/06/04 18:36
 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>
0 0
原创粉丝点击