如何解决在 .NET 5 中使用带有 NEST 的谓词表达式
是否可以在 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)));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。