更新时间:2020-05-09 17:43
数据推送到OpenSearch后会先保存到离线数据表中,在此阶段,为了方便用户推送数据,数据表允许用户根据实际业务场景定义多个表(需要指定关联字段),并提供了数据处理的插件。数据处理完毕后会join成一张索引表,这种索引表主要定义搜索属性,供引擎构建索引及查询使用。
这里分别介绍下数据表与索引表的字段对应关系。
数据表主要为数据导入时使用,不同的数据处理插件对类型有不同的要求,这里只是初步类型选择,下一步将有更细化的类型。具体字段取值范围,请参见系统限制-字段相关部分说明。超过取值范围将溢出或者截断,请务必保证选择类型正确。
类型 | 说明 |
---|---|
INT | int64整型 |
INT_ARRAY | int64整型数组 |
FLOAT | 浮点型 |
FLOAT_ARRAY | 浮点型数组 |
DOUBLE | 浮点型 |
DOUBLE_ARRAY | 浮点型数组 |
LITERAL | 字符串常量,仅支持精确匹配 |
LITERAL_ARRAY | 字符串常量数组,单个元素仅支持精确匹配 |
SHORT_TEXT | 短文本,长度在100字节内,支持若干分词方式 |
TEXT | 长文本,支持若干分词方式 |
TIMESTAMP | int64整型,时间戳数据 |
GEO_POINT | 字符串常量,经纬度字段,格式为:”经度 纬度” |
ARRAY数组类型说明:
时间戳字段说明:
INT,INT_ARRAY,TEXT,SHORT_TEXT,LITERAL,LITERAL_ARRAY,TIMESTAMP,GEO_POINT
FLOAT,FLOAT_ARRAY,DOUBLE,DOUBLE_ARRAY
INT,INT_ARRAY,LITERAL,LITERAL_ARRAY,FLOAT,FLOAT_ARRAY,DOUBLE,DOUBLE_ARRAY,TIMESTAMP,GEO_POINT
TEXT,SHORT_TEXT
对于INT及FLOAT类型介绍这里不再累赘(限制详见系统限制),重点介绍下各字段类型。
搜索效果如何跟分词有很大的关系,分词方式直接影响最终的搜索效果展示,目前系统支持若干的分词方式,需要根据实际业务场景的需求选择合适的字段类型。
接下来,我们详细说明下各个字段的展现效果及适用场景,供大家参考。
不分词,适合一些需要精确匹配的场景。如标签、关键词等,不分词的字符串或数值内容。
该分析器适用于LITERAL、INT 字段类型。
例如:文档字段内容为“菊花茶”,则只有搜索“菊花茶”的情况下可以召回。
按照检索单元做分词,基于中文语义分词,适用于全网通用行业的分词器。属于行业分词类型。
该分析器适用于TEXT、SHORT_TEXT字段类型。
例如:文档字段内容为“菊花茶”,则搜索“菊花茶”、“菊花”、“茶”、“花茶”等情况下可以召回。
适用于新高级版/标准版应用,适用于电商行业的分词器。属于行业分词类型。
该分析器适用于TEXT、SHORT_TEXT字段类型。
例如:文档字段内容为“大宝SOD蜜”,则搜索“大宝”、“sod”、“sod蜜”、“SOD蜜”、“蜜”等情况下均可以召回。
按照单字/单词分词,适合非语义的中文搜索场景,如小说作者名称、店铺名等。
该分析器适用于TEXT、SHORT_TEXT字段类型。
例如:文档字段内容为“菊花茶”,则搜索“菊花茶”、“菊花”、“茶”、“花茶”、“菊”、“花”、“菊茶”等情况下可以召回。
仅适用于SHORT_TEXT短文本类型,支持拼音搜索、数字的前后缀搜索(中文不支持前后缀匹配搜索,字母,数字及拼音,这些都支持前后缀匹配)、单字或者单字母搜索。最多支持100个字节字段长度,更多介绍及注意事项参见模糊搜索使用说明
例如:文档字段内容为“菊花茶”,则搜索“菊花茶”、“菊花”、“茶”、“花茶”、“菊”、“花”、“菊茶”、“ju”、“juhua”、“juhuacha”、“j”、“jh”、“jhc”等情况下可以召回。
例如:文档字段内容为手机号“13812345678”,则通过“^138”来搜索以“138”开头的手机号,通过“5678$”搜索以“5678”结尾的手机号。
例如:文档字段内容为“OpenSearch”,则通过单个字母或者组合都可以检索到。
适合于英文语义搜索场景,对于分词后的每个英文单词默认会做去词根、单复数转化。
该分析器适用于TEXT、SHORT_TEXT字段类型。
例如:文档字段内容为“英文分词器 english analyzer”,则搜索“英文分词器”、“english”、“analyz”、“analyzer”、“analyzers”、“analyze”、“analyzed”、“analyzing”等情况下可以召回。
(注意:英文分词器中连续的中文会被分成一个词)
适合于英文书名、人名等搜索场景,按照空格及标点符号做分词。
该分析器适用于TEXT、SHORT_TEXT字段类型。
例如:文档字段内容为“英文分词器 english analyzer”,则搜索“英文分词器”、“english”、“analyzer”等情况下可以召回。。
(注意:英文分词器中连续的中文会被分成一个词)
仅适用于SHORT_TEXT短文本类型,支持对短文本中的汉字,按照首字母和拼音全拼进行检索。适用于人名、电影名等需要简拼和全拼搜索的场景,而且全拼检索时必须输入汉字的全拼,不能只输部分。
例如:文档字段内容为“大内密探007”,则搜索“d”、“dn”、“dnm”、“dnmt”、“dnmt007”、“da”、“danei”、“daneimi”、“daneimitan”等都可以召回。搜索“an”、“anei”等无法召回。
仅适用于SHORT_TEXT短文本类型,支持对短文本中的汉字,按照首字母进行检索。适用于人名、电影名等需要简拼搜索的场景。
例如:文档字段内容为“大内密探007”,则搜索“d”、“dn”、“dnm”、“dnmt”、“dnmt0”、“dnmt007”、“m”、“mt”、“mt007”、“007”等都可以召回。
适合特殊场景下系统自带无法解决的搜索场景,可以实现完全用户控制的效果。推送文档及搜索时使用制表符“\t”对字段内容(或查询词)进行分隔,注意二者分词的一致性,否则会导致无法召回文档的情况。
该分析器适用于TEXT、SHORT_TEXT字段类型。
例如:字段内容为“菊\t花茶\thao”,则只有查询词“菊”、“花茶”、“菊\t花茶”、“花茶\thao”、“菊\thao”、“菊\t花茶\thao”可以召回该文档。
适合需要按时间区间查询和数值类区间查询的搜索场景。
该分析器适用于INT、timestamp字段类型。
例如:query=default:'开放搜索' AND index:[number1,number2]
//此处index为配置了数值分析的索引名字。
数值分析具体的语法以及用法请点击此处查看。
适用于需要地理位置区间查询的场景。
该分析器适用于geo_point字段类型。
例如:query=spatial_index:'circle(116.5806 39.99624, 1000)'
//查询圆内的点, 可以用于附近若干公里的点查询
地理位置分析具体的语法以及用法请点击此处查看。
适用于面向IT行业的技术性内容的分词器,属于行业分词;和通用分词器相比,对一些IT技术相关的词分词结果会不一样。该分析器适用于TEXT,SHORT_TEXT字段类型。
例如:原始内容:c++数组使用注意事项
通用分析:c ++ 数 组 使用 注意 事项
IT-内容分析:c++ 数组 使用 注意 事项
行业分析器(通用分析/电商分析/人名分析)+自定义干预词条。具体用法参考自定义分词器文档。
该分析器适用于TEXT、SHORT_TEXT字段类型。
行业分析器以及自定义分析器的分析结果可以通过分析测试功能进行测试。前往应用控制台的应用列表界面 -> 高级配置 -> 自定义分析器 -> 分析测试,进行分析器分析结果的测试。
在文档使用中是否遇到以下问题
更多建议
匿名提交