微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

OData V4.01 和 EF Core - 选择集合类型的属性时出错

如何解决OData V4.01 和 EF Core - 选择集合类型的属性时出错

得到了一个具有 string[] 类型属性的实体:

public class Version {

    [Key,DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    [Column("id")]
    public int Id { get; set; }

    [Column("codes")]
    public string[] Codes{ get; set; }
}

转换为集合(Edm.String):

<EntityType Name="Version">
    <Key>
        <PropertyRef Name="Id" />
    </Key>
    <Property Name="Codes" Type="Collection(Edm.String)" />
</EntityType>

每当我将它包含在像这样的选择查询中时:

?$select=Codes

返回此错误

system.invalidOperationException: The LINQ expression '$it' Could not be translated. Either rewrite the query in a form that can be translated,or switch to client evaluation explicitly by inserting a call to 'AsEnumerable','AsAsyncEnumerable','ToList',or 'ToListAsync'. See https://go.microsoft.com/fwlink/?linkid=2101038 for more information.

控制器和 EF:

[EnableCors("AllowAll")]
public class VersionController : ODataController {

    private DbContext _context;

    public VersionController(DbContext context) {

        this._context = context;
    }

    [HttpGet]
    [EnableQuery]
    public IQueryable<Entities.Version> GetVersion() {
        return this._context.Version;
    }
}

无论表是否为空,都会失败。有任何想法吗?在 EF 翻译来自 OData 的集合的选择查询时,这似乎是一个问题。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。