我正在尝试在API中创建最简单的代理,以便在ElasticSearch节点上执行搜索。代理的唯一原因是“隐藏”凭证并从API端点抽象ES。
使用Nest.ElasticClient,有没有办法执行原始字符串查询? 在vanilla ES中有效的示例查询:
{
"query": {
"fuzzy": { "title": "potato" }
}
}
在我的API中,我尝试将原始字符串反序列化为SearchRequest,但它失败了。我假设它无法反序列化该字段:
var req = m_ElasticClient.Serializer.Deserialize<SearchRequest>(p_RequestBody);
var res = m_ElasticClient.Search<T>(req);
return m_ElasticClient.Serializer.SerializeToString(res);
System.InvalidCastException: Invalid cast from 'System.String' to 'Newtonsoft.Json.Linq.JObject'.
有没有办法将原始字符串查询转发给ES并返回字符串响应?我没有运气就尝试使用LowLevel.Search方法。
答案 0 :(得分:4)
NEST不支持反序列化Elasticsearch Query DSL的"field_name" : "your_value"
的简短格式,但它确实支持长格式"field_name" : { "value" : "your_value" }
,因此以下工作
var client = new ElasticClient();
var json = @"{
""query"": {
""fuzzy"": {
""title"": {
""value"": ""potato""
}
}
}
}";
SearchRequest searchRequest;
using (var stream = new MemoryStream(Encoding.UTF8.GetBytes(json)))
{
searchRequest = client.Serializer.Deserialize<SearchRequest>(stream);
}
作为Rob has answered,NEST还支持supplying a raw json string as a query
答案 1 :(得分:3)
是的,您可以使用NEST执行此操作,请查看以下内容
var searchResponse = client.Search<object>(s => s
.Type("type").Query(q => q.Raw(@"{""match_all"":{}}")));
希望有所帮助。