2016-09-01 51 views
1

我已经开始在C#项目中使用RavenDB。我有证件与结构:在RavenDB中处理带点的前缀

{ 
    "MessageId": "8c34dec8-e6fe-6bee-2dc6-2cf83e374090", 
    "Headers": { 
    "Header.MessageId": "14f6cdf3-142d-4ab0-9610-a65600f1f460", 
    "Header.Timestamp": "2016-08-02 12:40:55:783130 Z", 
    "$.diagnostics.host": "1ddc6cefd4d776f1de8fefc33a45d020", 
    }, 
    "Timestamp": "2016-08-02T12:43:25.3914940Z" 
} 

我可以得到的MessageId文件:

var doc = session.Query<Messages>().Where(w => w.MessageId == "8c34dec8-e6fe-6bee-2dc6-2cf83e374090").ToList(); 

但我想获得的文件:Headers.Header.MessageId。 不幸的是在标题中有前缀(Header和$)的键,我不知道如何处理它在session.Query<Messages>()声明。

我能做到这一点在RavenDB演播室:

from doc in docs.Messages 
where doc.Headers["Header.MessageId"] == "14f6cdf3-142d-4ab0-9610-a65600f1f460" 
select new { 
    Id = doc.MessageId, 
    MessageId = doc.Headers["Header.MessageId"] 
} 

我试图创建Lucene的查询,但它不工作:

var doc = session.Advanced.LuceneQuery<object>().WhereEquals("Headers.Header.MessageId", "14f6cdf3-142d-4ab0-9610-a65600f1f460").ToList(); 

你能告诉我什么,我做错了,帮我请?

回答

0

是您的文档是否由管理员创建?因为你的文档不能用.net类(也是通过消息)来表示(你不能使用点的属性名),这意味着你不能加载文档;您需要修补文档(去除点)