ElasticSearch:写入后立即查询数据

时间:2014-09-04 19:57:00

标签: c# elasticsearch nest elasticsearch-net

我要求能够在写入ES后立即通过密钥读取数据。这可能吗?请注意,DataMap是一个键值对,并且_id被修改为关键字段。

string v = "Foobar" + i;
string k = Security.Hash(Encoding.UTF8.GetBytes(v));

var data = new DataMap { Key = k, Value = v };
var index = _esclient.Index(data);

// fetch by k
var results = _esclient.Search<DataMap>(p => p
        .Size(1000)
        .Fields(f => f.Key, f => f.Value)
        .Query(q => q.Term("key", k))
        );

// Make sure the record is found
if (!results.Hits.Any())
{
    Console.WriteLine("{0} {1} not found", k, v);
}

1 个答案:

答案 0 :(得分:1)

是。 GET API为realtime,并在收到文档后立即通过其_id返回文档,即使索引尚未刷新。

请注意,为Elasticsearch提供唯一的_id可能更简单,而不是让它为您生成一个。否则,您必须阅读索引操作的响应,以了解文档的_id