问题描述
是否可以在 nesT (.NET 5) 中配置一种对所有 nesT 查询(GetAsync、GetManyAsync)使用默认谓词表达式(默认查询过滤器)的方法、SearchAsync、ExistsAsync、...) 对任何索引执行?
我们的想法是像在 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)));