gpt4 book ai didi

asp.net-web-api - WebAPI、oData 和 RavenDb - 引发 $top 和 $skip 错误

转载 作者:行者123 更新时间:2023-12-03 02:32:48 24 4
gpt4 key购买 nike

我正在使用 WebAPI 从 RavenDb 返回基本供应商对象的集合

供应商类别是:

public class Supplier
{
public string Id { get; set; }
public string Title { get; set; }
}

WebAPI 方法是:

[Queryable]
public IQueryable<Supplier> Get()
{
using (var session = _store.OpenSession())
{
return session.Query<Supplier>();
}
}

当我调用 http://localhost:8083/api/suppliers?$orderby=Id%20deschttp://localhost:8083/api/suppliers?$filter=标题%20eq%20'测试'一切正常。但是,每当我使用 $top 或 $skip 时,我都会遇到异常:

无法将“System.Linq.Expressions.PropertyExpression”类型的对象转换为“System.Linq.Expressions.ConstantExpression”类型。

如果我使用 ToList() 将整个集合返回到内存中,它工作正常,因此看起来像是使用 RavenDb 延迟执行查询的问题。

我使用的是 RavenDb.Client 2.0.2.2261 的最新稳定版本。

还有其他人遇到过这个问题或者有解决办法吗?

堆栈跟踪是:

   at Raven.Client.Linq.RavenQueryProviderProcessor`1.VisitQueryableMethodCall(MethodCallExpression expression) in c:\Builds\RavenDB-Stable\Raven.Client.Lightweight\Linq\RavenQueryProviderProcessor.cs:line 994
at Raven.Client.Linq.RavenQueryProviderProcessor`1.VisitMethodCall(MethodCallExpression expression, Boolean negated) in c:\Builds\RavenDB-Stable\Raven.Client.Lightweight\Linq\RavenQueryProviderProcessor.cs:line 693
at Raven.Client.Linq.RavenQueryProviderProcessor`1.VisitExpression(Expression expression) in c:\Builds\RavenDB-Stable\Raven.Client.Lightweight\Linq\RavenQueryProviderProcessor.cs:line 140
at Raven.Client.Linq.RavenQueryProviderProcessor`1.GetLuceneQueryFor(Expression expression) in c:\Builds\RavenDB-Stable\Raven.Client.Lightweight\Linq\RavenQueryProviderProcessor.cs:line 1318
at Raven.Client.Linq.RavenQueryProviderProcessor`1.Execute(Expression expression) in c:\Builds\RavenDB-Stable\Raven.Client.Lightweight\Linq\RavenQueryProviderProcessor.cs:line 1352
at Raven.Client.Linq.RavenQueryProvider`1.Execute(Expression expression) in c:\Builds\RavenDB-Stable\Raven.Client.Lightweight\Linq\RavenQueryProvider.cs:line 135
at Raven.Client.Linq.RavenQueryProvider`1.System.Linq.IQueryProvider.Execute(Expression expression) in c:\Builds\RavenDB-Stable\Raven.Client.Lightweight\Linq\RavenQueryProvider.cs:line 190
at Raven.Client.Linq.RavenQueryInspector`1.GetEnumerator() in c:\Builds\RavenDB-Stable\Raven.Client.Lightweight\Linq\RavenQueryInspector.cs:line 99
at System.Collections.Generic.List`1..ctor(IEnumerable`1 collection)
at System.Linq.Enumerable.ToList[TSource](IEnumerable`1 source)
at Newtonsoft.Json.Serialization.JsonArrayContract.CreateWrapper(Object list)
at Newtonsoft.Json.Serialization.JsonSerializerInternalWriter.SerializeValue(JsonWriter writer, Object value, JsonContract valueContract, JsonProperty member, JsonContainerContract containerContract, JsonProperty containerProperty)
at Newtonsoft.Json.Serialization.JsonSerializerInternalWriter.Serialize(JsonWriter jsonWriter, Object value)
at Newtonsoft.Json.JsonSerializer.SerializeInternal(JsonWriter jsonWriter, Object value)
at Newtonsoft.Json.JsonSerializer.Serialize(JsonWriter jsonWriter, Object value)
at System.Net.Http.Formatting.JsonMediaTypeFormatter.<>c__DisplayClassd.<WriteToStreamAsync>b__c()
at System.Threading.Tasks.TaskHelpers.RunSynchronously(Action action, CancellationToken token)

最佳答案

我能够重现您的问题,并成功验证我对可能出现问题的最初猜测。尝试使用 [Queryable(EnableConstantParameterization = false)] 而不是普通的 [Queryable]。在 OData 开发周期的后期,我们进行了性能更改以充分利用 EF automatic compilation of LINQ queries.我们默认启用它,因为这是一个安全的更改。不幸的是,我认为 RavenDB LINQ 提供程序无法理解通过此优化生成的 LINQ 查询。我共享的代码将其关闭并生成普通 LINQ 查询。

关于asp.net-web-api - WebAPI、oData 和 RavenDb - 引发 $top 和 $skip 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15318977/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com