首页 > 其他 > 详细

无法将类型“System.Nullable`1”强制转换为类型“System.Object”。LINQ to Entities 仅支持强制转换 EDM 基元或枚举类型。

时间:2016-06-04 11:55:50      阅读:1459      评论:0      收藏:0      [点我收藏+]

 

 

 在一个项目中使用LINQ和EF时出现了题目所示的异常,搜索了很多资料都找不到解决办法,主要是因为EF方面的知识欠缺。

 先将情况记录如下,以供以后参考。

 查询主要设计两张表,由外键关联:

  技术分享

在进行下面的查询时,出现异常:无法将类型“System.Nullable`1”强制转换为类型“System.Object”。LINQ to Entities 仅支持强制转换 EDM 基元或枚举类型。

 public ActionResult GetIpSegments()
        {
            //List<Ipsegment> ipsegments = (from s in deviceDB.Ipsegment select s).ToList();
            var ipsegments = from d in deviceDB.DeviceCategory
                             join s in deviceDB.Ipsegment
                             on d.devicecategoryid equals s.devicecategoryid
                             select new
                                        {
                                            devicecategoryid1 = s.devicecategoryid,
                                            devicecategoryname1 = d.devicecategoryname,
                                            ipsegment = "202.115.242." + s.ip_head + "-202.115.242." + s.ip_end
                                        };

            return Json(ipsegments, JsonRequestBehavior.AllowGet);
        }

 后来,对查询做了修改,才成功。修改后的查询如下所示:

    public ActionResult GetIpSegments()
        {
            var ipsegments = from s in deviceDB.Ipsegment
                             select new
                             {
                                 s.devicecategoryid,
                                 s.DeviceCategory.devicecategoryname,
                                 s.ip_head,
                                 s.ip_end
                             };

            return Json(ipsegments, JsonRequestBehavior.AllowGet);
        }

这其中的原因,现在还不了解,等了解后再作补充。

无法将类型“System.Nullable`1”强制转换为类型“System.Object”。LINQ to Entities 仅支持强制转换 EDM 基元或枚举类型。

原文:http://www.cnblogs.com/wangyihome/p/5552310.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!