gpt4 book ai didi

c# - Elasticsearch 转义空格的正确方法,?并非在所有情况下都有效

转载 作者:行者123 更新时间:2023-11-30 18:15:25 26 4
gpt4 key购买 nike

我正在尝试使用空格进行搜索以在 elasticsearch 中正常工作,但在让它的行为方式与在另一个字段中的行为方式相同时遇到了很多麻烦。

我有两个字段,NameAddresses.First().Line1我希望能够搜索并保留搜索中的空格。例如,搜索 Bob Smi*会返回 Bob Smith但不仅仅是Bob .

通过用 ? 替换空格进行查询字符串搜索,这对我的 Name 字段有效.我也在做通配符,所以我的最终查询是 *bob?smi* .

但是,当我尝试同时按第 1 行搜索时,我没有得到任何结果。例如。 *4800*返回第 1 行的记录,如 4800 Street ,但是当我对 4800 street 进行相同的转换时得到*4800?street* ,我没有得到任何结果。

下面是我的查询

{
"from": 0,
"size": 50,
"query": {
"bool": {
"must": [
{
"query_string": {
"query": "*4800?Street*",
"fields": [
"name",
"addresses.line1"
]
}
}
]
}
}
}

没有返回结果。

为什么 *bob?smi*返回名称为 Bob Smith 的结果但是*4800?street*不返回带有行项目的结果 4800 street

下面是两个字段在索引中的设置方式:

.Text(smd => smd.Name(c => c.Name).Analyzer(ElasticIndexCreator.SortAnalyzer).Fielddata())

.Nested<Address>(nomd => nomd.Name(p => p.PrimaryAddress).Properties(MapAddressProperties))

//from MapAddressProperties()

.Text(smd2 => smd2.Name(x => x.Line1).Analyzer(ElasticIndexCreator.SortAnalyzer).Fielddata())

弹性映射:

"name": {
"type": "text",
"fields": {
"keyword": {
"type": "keyword",
"ignore_above": 256
}
}
}
}
"addresses": {
"line1": {
"type": "text",
"fields": {
"keyword": {
"type": "keyword",
"ignore_above": 256
}
}
},
}

是否有其他更好的方法来转义 elasticsearch 查询字符串中的空格?我也试过 \\\\\\ (在 C# 中计算为 \\ )而不是 ?无济于事。

最佳答案

经过大量时间的试验,终于找到了正确的设置。对我有用的配置如下:

  1. 在列中使用带有字段数据的文本
  2. 使用带有通配符占位符的 QueryString 进行搜索,用 ? 替换空格,例如输入bob smith,查询elastic with *bob?smith*
  3. 对子对象使用嵌套查询。奇怪的是,addresses.line1 会在搜索 say 4800 时返回数据,但在尝试执行 *4800?street* 时不会返回数据。使用嵌套查询可以使其正常运行。

据我所知,必须使用字段数据会占用大量内存,而必须使用通配符会占用大量时间,因此这可能不是最佳解决方案,但这是我找到的唯一解决方案。如果还有其他更好的方法,请赐教。

在 C# 中使用 Nest 的示例查询:

var query = Query<Student>.QueryString(qs => qs
.Fields(f => f
.Field(c => c.Name)
//.Field(c => c.PrimaryAddress.Line1) //this doesn't work
)
.Query(testCase.Term)
);

query |= Query<Student>.Nested(n => n
.Path(p => p.Addresses)
.Query(q => q
.QueryString(qs => qs
.Fields(f => f.Field(c => c.Addresses.First().Line1))
.Query(testCase.Term)
)
)
);

示例映射:

.Map<Student>(s => s.Properties(p => p
.Text(t => t.Name(z => z.Name).Fielddata())
.Nested<StudentAddress>(n => n
.Name(ap => ap.Addresses)
.Properties(ap => ap.Text(t => t.Name(z => z.Line1).Fielddata())
)
))

关于c# - Elasticsearch 转义空格的正确方法,?并非在所有情况下都有效,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48327763/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com