用RavenDb查询字典

bas*_*rat 6 ravendb

我有一个类定义为:

public class Student
{
    public string Id { get; set; }
    public IDictionary<string, string> Attributes { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

基于我在此处发现的讨论:http://groups.google.com/group/ravendb/browse_thread/thread/88ea52620021ed6c?pli = 1

我可以很容易地存储一个实例:

//creation
using (var session = store.OpenSession())
{               
    //now the student:
    var student = new Student();
    student.Attributes = new Dictionary<string, string>();

    student.Attributes["NIC"] = "studentsNICnumberGoesHere";               
    session.Store(student);
    session.SaveChanges();
}
Run Code Online (Sandbox Code Playgroud)

但是,当我查询如下:

//Testing query on attribute
using (var session = store.OpenSession())
{
    var result = from student in session.Query<Student>()
                 where
                     student.Attributes["NIC"] == "studentsNICnumberGoesHere"
                  select student;

    var test = result.ToList();                
}           
Run Code Online (Sandbox Code Playgroud)

我收到错误"'System.Linq.Expressions.InstanceMethodCallExpressionN'以输入'System.Linq.Expressions.MemberExpression'." 如图所示:

在此输入图像描述 如何根据字典中的键进行查询?

Aye*_*ien 14

这是一个错误,现在已修复.将在大约两个小时内出现在下一个版本中

  • 永远荣幸地阅读你写的任何东西 (3认同)