如何解决OData V4.01 和 EF Core - 选择集合类型的属性时出错
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 举报,一经查实,本站将立刻删除。