异常消息为在数据上下文类型上,存在元素类型不是实体类型的顶级IQueryable属性

本文关键字:类型 实体 属性 IQueryable 元素 存在 消息 数据 上下文 异常 | 更新日期: 2023-09-27 18:30:03

我正在构建IIS 7中托管的WCFDataService,我将使用反射提供程序作为数据源提供程序。如果我将实体类型定义保留在定义服务的同一程序集中,则我的项目有效,但如果我将该实体类型移动到另一个引用的程序集,则项目无效;

我得到以下错误:

"服务器在处理请求时遇到错误。异常消息为"在数据上下文类型"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类移动到引用的程序集时遇到了错误

我缺了什么?

异常消息为在数据上下文类型上,存在元素类型不是实体类型的顶级IQueryable属性

两个小时后,我自己发现了这个问题,我在我的服务中引用了Microsoft.Data.Services.Client,在我要移动实体类型的引用项目库中引用了System.Data.Services.Client。希望我的帖子能帮助其他人。

除此之外,在经历了一天的头痛之后,我找到了EntityFramework模型6.0.4的解决方案。它需要Microsoft.OData.EntityFrameworkProvider程序集和WcfDataService类从EntityFrameworkDataService派生,如下所示:

    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;
        }
    }
}