无法从Linq转换Odata查询 [英] Odata Query can't be translated from Linq

查看:40
本文介绍了无法从Linq转换Odata查询的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试使OData查询在.Net Core 3.1上工作

在.Net Core 2.1上一切运行正常 现在升级后显示

System.InvalidOperationException:LINQ表达式‘$it’无法 被翻译。将查询重写为可以 转换,或通过插入 调用AsEnumerable()、AsAsyncEnumerable()、ToList()或 ToListAsync()。

我有两张表

    public class WorkItem
    {
        [Key]
        [Required]
        public Guid Id { get; set; }

        [Required]
        [MaxLength(128)]
        public string Name { get; set; }

        public IEnumerable<Resource> Resources { get; set; }

        public WorkItem(string name)
        {      
            Name = name;
        }
    }

public class Resource
    {
        [Key]
        [Required]
        public Guid Id { get; set; }

        [Required]
        public Guid WorkItemId { get; set; }

        [Required]
        [MaxLength(128)]
        public string Name { get; set; }

        [Required]
        public Guid StorageId { get; set; }

        public DateTime CreateDate { get; set; }

        public ContentItem ContentItem { get; set; }

        public AppItem AppItem { get; set; }

        public Resource(Guid workItemId, string name, Guid storageId)
        {
            WorkItemId = workItemId;
            Name = name;
            StorageId = storageId;
        }
    }

然后请求URI如下所示:

_appItemsBaseUri/response.Id?$expand=Resources($filter=Name eq‘test2.pdf’)";

成功命中接口,过滤数据,创建Odata SingleResult。如果我展开它,我可以看到有一个工作项和资源在那里。

var dto = dataset.Where(workItemId==responseId);
var res = SingleResult.Create(dto);

但当我返回时,它不会从API返回

// This results in the error mentioned above.
return Ok(res);

我能让它工作的唯一方法就是这样使用它...

var dto = dataset.Where(workItemId==responseId);
var res = SingleResult.Create(dto).Queryable.FirstOrDefault();
return Ok(res)
我正在使用以下程序包版本 Microsoft.AspNetCore.Odata 7.3.0 Microsoft.EntityFrameworkCore 3.1.0

请告诉我如何才能返回数据而不必执行客户端评估(.Queryable.FirstOrDefault())? 代码需要进行客户端评估的原因是什么,因为我可以看到没有需要客户端评估的代码?

推荐答案

我遇到了同样的问题,不仅是在单个结果上,在我尝试筛选子集合时也是如此。问题似乎出在实体框架3.1.0上。看起来像是实体框架3.1.0。如果无法将查询转换为SQL查询,则将引发异常。之前,ef核心执行一个查询以获取内存中的所有数据,并在之后处理该查询。 我的解决方案是使用FirstOrDefault或ToList().AsQueryable()。但当然,如果我们在表中有大量数据,这可能会导致性能问题。

这篇关于无法从Linq转换Odata查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆