2

我正在使用Sqlite.Net Extensions库从我的数据库中获取对象。

我有一个列表,Id's我想从我的列表包含该 ID 的数据库中获取所有对象。

我有以下内容:

var filteredCalls = listOfIds;            
var conn = Databsae.Connection;
var NewCalls = conn.GetAllWithChildren<Call>(x => filteredCalls.Any(y => y == x.Id));

但是此代码返回错误:

[错误] 致命的未处理异常:System.Reflection.TargetInvocationException:调用目标已引发异常。---> System.NotSupportedException: 无法编译: Lambda 08-30 15:46:57.210 E/mono-rt (16849): 在 SQLite.Net.TableQuery 1[T].CompileExpr (System.Linq.Expressions.Expression expr, System.Collections.Generic.List1 queryArgs) [0x007aa] in :0 08-30 15:46 :57.210 E/mono-rt (16849): 在 SQLite.Net.TableQuery 1[T].CompileExpr (System.Linq.Expressions.Expression expr, System.Collections.Generic.List1 queryArgs) [0x001a5] in :0 08-30 15:46:57.210 E/mono-rt (16849): 在 SQLite.Net.TableQuery 1[T].GenerateCommand (System.String selectionList) [0x0006d] in <filename unknown>:0 08-30 15:46:57.210 E/mono-rt (16849): at SQLite.Net.TableQuery1 [T].GetEnumerator () [0x00008] in :0 08-30 15:46:57.210 E/mono-rt (16849): 在 System.Collections.Generic.List1[T]..ctor (IEnumerable1 个集合)[0x00073] 在 /Users/builder/data/lanes/3540/1cf254db/source/mono/external/referencesource/mscorlib/system/collections/generic/list.cs:98 08-30 15:46:57.210 E /mono-rt (16849): 在 System.Linq.Enumerable.ToList[TSource] (IEnumerable 1 source) [0x00011] in /Users/builder/data/lanes/3540/1cf254db/source/mono/external/referencesource/System.Core/System/Linq/Enumerable.cs:835 08-30 15:46:57.210 E/mono-rt (16849): at SQLiteNetExtensions.Extensions.ReadOperations.GetAllWithChildren[T] (SQLite.Net.SQLiteConnection conn, System.Linq.Expressions.Expression1 过滤器,布尔递归) [0x00015] 在 /Users/redent/Documents/workspace/sqlite-net-extensions/SQLiteNetExtensions/Extensions/读取操作.cs:60

那么我应该如何在GetAllWithChildren不崩溃的情况下使用该方法呢?文档非常稀疏

额外的

这是实现该方法的行

Sqlite 中可能不支持 lambda 表达式,如此处所述如果是这种情况,替代方案是什么/应该如何使用这种方法?

4

1 回答 1

3

所以看起来Sqlite.Net无法处理嵌套在另一个 lamdba 表达式中的 Lambda 表达式。因此,我将过滤器更改为:

var NewCalls = conn.GetAllWithChildren<DiaryCall>(x => filteredCalls.Contains(x.Id));
于 2016-08-30T15:24:15.353 回答