val*_*lps 5 odata ravendb asp.net-web-api
我正在使用WebAPI从RavenDb返回一组基本的Supplier对象
供应商类别是:
public class Supplier
{
public string Id { get; set; }
public string Title { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
WebAPI方法是:
[Queryable]
public IQueryable<Supplier> Get()
{
using (var session = _store.OpenSession())
{
return session.Query<Supplier>();
}
}
Run Code Online (Sandbox Code Playgroud)
当我打电话http://localhost:8083/api/suppliers?$orderby=Id%20desc或http://localhost:8083/api/suppliers?$filter=Title%20eq%20'Test'
一切正常.但是,每当我使用$ 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)
Run Code Online (Sandbox Code Playgroud)
我能够重现你的问题,并成功地验证了我最初的猜测是什么可能出错.尝试[Queryable(EnableConstantParameterization = false)]而不是简单[Queryable].在OData开发周期的后期,我们进行了一次性能更改,以便最佳地使用LINQ查询的EF自动编译.我们默认启用它,因为它是一个安全的更改.不幸的是,我认为RavenDB LINQ提供程序无法理解通过此优化生成的LINQ查询.我共享的代码将其关闭并生成vanilla LINQ查询.
| 归档时间: |
|
| 查看次数: |
1095 次 |
| 最近记录: |