ES _all、_source的使用——_all字段连接所有字段的值构成一个用空格(space)分隔的大string而被analyzed和index,document主体保存在_source中
1._all
1.1_all field
_all字段是一个很少用到的字段,它连接所有字段的值构成一个用空格(space)分隔的大string,该string被analyzed和index,但是不被store。当你不知道不清楚document结构的时候,可以用_all。如,有一document:
- curl -XPUT 'http://127.0.0.1:9200/myindex/order/0508' -d '{
- "name": "Scott",
- "age": "24"
- }'
用_all字段search:
- curl -XGET "http://127.0.0.1:9200/myindex/order/_search?pretty" -d '{
- "query": {
- "match": {
- "_all": "Scott 24"
- }
- }
- }'
注意:_all是按空格(space)分隔的,所以,对于date类型就被analyzed为["year", "month", "day"]。如,一document:
- {
- "first_name": "John",
- "last_name": "Smith",
- "date_of_birth": "1970-10-24"
- }
- curl -XGET "http://127.0.0.1:9200/myindex/order/_search?pretty" -d '{
- "query": {
- "match": {
- "_all": "john smith 1970"
- }
- }
- }'
_all字段将包含["john", "smith", "1970", "10", "24"]。
所以,_all 字段仅仅是一个经过分析的 string 字段。它使用默认的分析器来分析它的值,而不管这值本来所在的字段指定的分析器。而且像所有 string 类型字段一样,你可以配置 _all 字段使用的分析器:
- PUT /myindex/order/_mapping
- {
- "order": {
- "_all": { "analyzer": "whitespace" }
- }
- }
1.2 Disable _all field
_all字段需要额外的CPU周期和更多的磁盘。所以,如果不需要_all,最好将其禁用!
1.3 Excluding fields from _all
你可能不想把_all禁用,而是希望_all包含某些特定的fields。通过include_in_all选项可以控制字段是否要被包含在_all字段 中,默认值是true。在一个对象上设置include_in_all可以修改这个对象所有字段的默认行为。如,指定_all包含name:
- PUT /myindex/order/_mapping
- {
- "order": {
- "include_in_all": false,
- "properties": {
- "name": {
- "type": "string",
- "include_in_all": true
- },
- ...
- }
- }
- }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」