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();
你能告诉我什么,我做错了,帮我请?