异常消息是On数据上下文类型,有一个顶级IQueryable属性,其元素类型不是实体类型

时间:2014-11-11 12:20:13

标签: c# .net wcf odata wcf-data-services

我正在构建我在IIS 7中托管的WCFDataService,我将使用Reflection Provider作为数据源提供程序。 如果我将实体类型定义保留在我定义服务的同一个程序集中,那么我的示例工作,但如果我将实体类型移动到另一个引用的程序集,则dosen&t; t工作 有以下错误

  

"服务器在处理请求时遇到错误。异常消息是'在数据上下文类型' EntityContainer'中,有一个顶级IQueryable属性' Cats'其元素类型不是实体类型"

服务

public class WcfDataService1 : DataService<EntityContainer>
    {

        public static void InitializeService(DataServiceConfiguration config)
        {
            config.SetEntitySetAccessRule("Cats", EntitySetRights.AllRead);
            config.DataServiceBehavior.MaxProtocolVersion = DataServiceProtocolVersion.V3;

        }
    }

实体容器

public class EntityContainer
    {
        public IQueryable<Cat> Cats
        {
            get
            {
                var s = new List<Cat>();
                var c1 = new Cat {Id = 1, Name = "Fufi"};
                var c2 = new Cat {Id = 1, Name = "Felix"};
                s.Add(c1);
                s.Add(c2);
                return s.AsQueryable();
            }
        }

    }

实体类型

[DataServiceKey("Id")]
public  class Cat 
{
     public int Id { get; set; }

     public string Name { get; set; }
}

现在正如我上面说的那样,如果我将类Cat与其他代码保持在一起,那么我会说错,但如果我将Cat移动到引用的程序集中我会收到错误

我缺少什么?

2 个答案:

答案 0 :(得分:5)

经过2个小时强烈的头痛我自己发现了问题,我在我的服务中引用了Microsoft.Data.Services.Client,在引用的项目库中引用了System.Data.Services.Client,我将要移动实体类型。希望我的帖子可以帮助别人。谢谢

答案 1 :(得分:0)

另外,在一天的辛苦,剧烈的头痛之后,我自己的作者回答了我找到的EntityFramework模型6.0.4解决方案。需要从EntityFrameworkDataService派生Microsoft.OData.EntityFrameworkProvider程序集和WcfDataService类,如下所示:

    public class WcfDataService1 : EntityFrameworkDataService<EntityContainer>
    {
        // This method is called only once to initialize service-wide policies.
        public static void InitializeService(DataServiceConfiguration config)
        {
            // TODO: set rules to indicate which entity sets and service operations are visible, updatable, etc.
            config.DataServiceBehavior.MaxProtocolVersion = DataServiceProtocolVersion.V3;
        }
    }
}