NEST 2.0 不会将某些字段持久化到 ElasticSearch 2.0 中



这是我的文档:

[ElasticsearchType(Name = "MyDoc")]
public class MyDoc: Dictionary<string, object>
{
    [String(Store = false, Index = FieldIndexOption.NotAnalyzed)]
    public string text { get; set; }
}

如您所见,它继承自Dictionary<string, object>因此我可以动态地向其添加字段(这是使聚合工作的要求)

在这里我存储映射:

client.Map<MyDoc>(m => m.Index("myindexname").AutoMap());

现在我创建一个新记录并存储它:

 var rec= new MyDoc();
 rec.Add("id", "mystuff");
 rec.text = "mytext";
 client.Index(rec, i => i.Index("myindexname"));
 client.Refresh("myindexname");

记录实际存储,但文本字段不会持久保存。这里是从 ElasticSearch 2.0 返回的 JSON

{
"_index": "myindexname",
"_type": "MyDoc",
"_id": "AVM3B2dlrjN2fcJKmw_z",
"_version": 1,
"_score": 1,
"_source": {
"id": "mystuff"
}
}

如果我从MyDoc中删除基类,则text字段存储正确,但显然字典内容没有(我还需要删除.Add()位,因为文档不是从Dictionary继承的)。

如何存储text字段和字典内容?

抱歉,

我在上一篇文章中写了错误的建议,所以我删除了它。我认为问题实际上是序列化,因为您的基类是字典

我会做两件事,首先尝试序列化您的对象以查看输出字符串,我很确定文本被忽略了。

其次我会把类改为以下

public class MyDoc : Dictionary<string, object>
    {
        public string text
        {
            get
            {
                object mytext;
                return TryGetValue("text", out mytext) ? mytext.ToString() : null;
            }
            set { this.Add("text", value);}
        }
    }

附言。正如我认为问题出在 c# 方面,因为您从字典继承,

var rec = new MyDoc();
rec.Add("id", "mystuff");
rec.text = "mytext";
//Text2 is property         public string text2 { get; set; }
rec.text2 = "mytext2";
var test = JsonConvert.SerializeObject(rec); //{"id":"mystuff","text":"mytext"}

最新更新