领域dotnet - 二元运算符的rhs' Equal'应该是常量或闭包变量表达式

时间:2016-05-25 12:43:49

标签: .net realm

您刚刚开始使用Realm dotnet

当我执行像

这样的简单查询时
var results = realm.All<MyRealmType>().Where(x => x.Property == otherVariable.Property);

所以在Where子句中,我正在比较两个字符串以从领域中检索我需要的数据。

我收到以下错误

{System.NotSupportedException: The rhs of the binary operator 'Equal' should be a constant or closure variable expression
  at Realms.RealmResultsVisitor.VisitBinary (System.Linq.Expressions.BinaryExpression b) [0x000cb] in <filename unknown>:0 
  at Realms.ExpressionVisitor.Visit (System.Linq.Expressions.Expression exp) [0x000d2] in <filename unknown>:0 
  at Realms.RealmResultsVisitor.VisitMethodCall (System.Linq.Expressions.MethodCallExpression m) [0x0006a] in <filename unknown>:0 
  at Realms.ExpressionVisitor.Visit (System.Linq.Expressions.Expression exp) [0x000ec] in <filename unknown>:0 
  at Realms.RealmResults`1[T].CreateResultsHandle () [0x00037] in <filename unknown>:0 
  at Realms.RealmResults`1[T].get_ResultsHandle () [0x0000d] in <filename unknown>:0 
  at Realms.RealmResults`1[T].GetEnumerator () [0x00000] in <filename unknown>:0 
  at System.Collections.Generic.List`1[T]..ctor (IEnumerable`1 collection) <0x1001aa7e0 + 0x001df> in <filename unknown>:0 
  at System.Linq.Enumerable.ToList[TSource] (IEnumerable`1 source) <0x100659e70 + 0x0004b> in <filename unknown>:0 
  at MyNamespace.MyMethod (System.Collections.Generic.List`1 myListList) [0x000b0] in C:\PathToMyFile\MyFile.cs:140 }   System.NotSupportedException

我不确定这意味着什么。这是否意味着我的Where子句只能使用硬编码字符串或int,如下例所示?

var results = realm.All<MyRealmType>().Where(x => x.Property == "stringToCompare");

如果是这样,这似乎非常有限。有谁知道如何解决这个问题。

提前致谢。

2 个答案:

答案 0 :(得分:4)

Will提供的答案确实有效,例如您必须将查询字词复制到单独的变量

var queryTerm = otherVariable.Property;
var results = realm.All<MyRealmType>().Where(x => x.Property == queryTerm);

也许来自Realm的人可以解释为什么会这样,以及将来是否会修复它。我怀疑它与Weaver有关。只是一个猜测。

再次感谢Will

答案 1 :(得分:1)

试试这个(它对我有用):

        System.Func<YourItem, bool> predicate = (YourItem item) =>
        {
            return !item.BoolProperty && item.ParentID == parent?.ID;
        };
        return Realms.Realm.GetInstance().All<YourItem>().Where(predicate).OrderBy(item => item.Position).ToList();