在 .NET 5 中使用带有 NEST 的谓词表达式

问题描述

是否可以在 nesT (.NET 5) 中配置一种对所有 nesT 查询GetAsyncGetManyAsync)使用认谓词表达式(查询过滤器)的方法SearchAsyncExistsAsync、...) 对任何索引执行?

我们的想法是像在 Entity Frameork 中那样工作,使用 HasQueryFilter,例如:

builder.HasQueryFilter(m => m.DeletedAt == null);

在所有查询中,表达式 DeletedAt == null 被插入到查询中。

解决方法

您可以利用 GlobalQueryStringParameters 中的 ConnectionSettings 方法,但似乎查询参数将发送到支持查询参数 (q) 的那些,如 search endpoint

并且您将无法使用例如GetAsync 因为它不支持 q 参数。

var indexName = "test";
var connectionSettings = new ConnectionSettings(new Uri("http://localhost:9200"));
connectionSettings.EnableDebugMode();
connectionSettings.DefaultIndex(indexName);
var nameValueCollection = new NameValueCollection();
nameValueCollection.Add("q","deletedAt: null");
connectionSettings.GlobalQueryStringParameters(nameValueCollection);
var elasticClient = new ElasticClient(connectionSettings);

var searchResponse = await elasticClient.SearchAsync<EsDocument>(s => s.Query(q => q.Term("id",1)));

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...