Elasticsearch 映射参数详解 fields
Elasticsearch 映射参数 fields
fields
处于不同的目的,通过不同的方法索引相同的字段通常非常有用。这也是多字段的目的。例如,一个字符串字段可以映射为text字段用于全文本搜索,也可以映射为keyword字段用于排序或聚合。
PUT my_index
{
"mappings": {
"_doc": {
"properties": {
"city": {
"type": "text",
"fields": {
"raw": {
"type": "keyword"
}
}
}
}
}
}
}
note:city.raw字段是city字段的keyword版本。
GET my_index/_search
{
"query": {
"match": {
"city": "york"
}
},
"sort": {
"city.raw": "asc"
},
"aggs": {
"Cities": {
"terms": {
"field": "city.raw"
}
}
}
}
note:city字段用于全文本搜索。
note:city.raw用于排序与聚合。
多字段不能修改原始_source字段。
对于相同索引中具有相同名称的字段,fields设置允许有不同的设置。可以使用PUT映射API将新的多字段添加到已存在的字段中。
带有多个分析的多字段
多字段的另一个应用场景是使用不同的方法分析相同的字段以求获得更好的相关性。
PUT my_index
{
"mappings": {
"_doc": {
"properties": {
"text": {
"type": "text",
"fields": {
"english": {
"type": "text",
"analyzer": "english"
}
}
}
}
}
}
}
note:text.field字段使用english分析器。
elasticsearch注解实现fields
mapping效果:
"label": {
"type": "keyword",
"fields": {
"IKS": {
"type": "text",
"analyzer": "ikIndexAnalyzer"
}
}
}
@Column(name = "标签")
@MultiField(
mainField = @Field(type = FieldType.Keyword),
otherFields = {
@InnerField(suffix = "IKS", type = FieldType.Text, analyzer = "ikIndexAnalyzer")
}
)
protected String label;
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
关于springboot中对sqlSessionFactoryBean的自定义
这篇文章主要介绍了springboot中对sqlSessionFactoryBean的自定义方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-12-12
解决IDEA2021版compiler.automake.allow.when.app.running不存在的问题
很多文章介绍IntelliJ IDEA开启热部署功能都会写到在IntelliJ IDEA中的注册表中开启compiler.automake.allow.when.app.running选项,此选项在IntelliJ IDEA 2021.2之后的版本迁移到高级设置中,下面看下设置方法2021-09-09
Maven 继承父工程时的relativePath标签详细解析
这篇文章主要介绍了Maven 继承父工程时的relativePath标签解析,通过本文学习你需要注意子模块想要用父模块pom中的版本,请注意配置relativePath属性,需要的朋友可以参考下2022-12-12
解决Spring Boot 多模块注入访问不到jar包中的Bean问题
这篇文章主要介绍了解决Spring Boot 多模块注入访问不到jar包中的Bean问题。具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-09-09


最新评论