Elasticsearch(ES) 查询指定返回字段
一则或许对你有用的小广告
欢迎加入小哈的星球 ,你将获得:专属的项目实战 / Java 学习路线 / 一对一提问 / 学习打卡/ 赠书活动
目前,正在
星球
内带小伙伴们做第一个项目:全栈前后端分离博客项目,采用技术栈 Spring Boot + Mybatis Plus + Vue 3.2 + Vite 4
,手把手,前端 + 后端全栈开发,从 0 到 1 讲解每个功能点开发步骤,1v1 答疑,陪伴式直到项目上线,目前已更新了 138 小节,累计 21w+ 字,讲解图:905 张,还在持续爆肝中,后续还会上新更多项目,目标是将 Java 领域典型的项目都整上,如秒杀系统、在线商城、IM 即时通讯、权限管理等等,已有 350+ 小伙伴加入,欢迎点击围观
。
Elasticsearch(ES) API 允许在查询时指定返回字段,也就是仅仅返回部分字段。
按需索取,能够提高 Elasticsearch 的响应速度。
一、仅显示部分字段
入参格式,如下:
{
"_source": [
"commodity_id",
"commodity_name"
],
"query": {
"query_string": {
"query": "荣耀"
}
}
}
通过_source
字段来指定需要返回的字段, 这里我们仅显示 commodity_id
、commodity_name
字段。
通过 HEAD 插件,看下实际效果:
二、不显示原始字段
将 _source
设置为 false
, 可以不显示原始字段,部分特殊场景下会用到。
{
"_source": false,
"query": {
"query_string": {
"query": "荣耀"
}
}
}
三、包含或排除某些字段
我们可以同时指定需要显示的字段的,和需要排除显示的字段:
{
"_source": {
"include": [
"commodity_id",
"commodity_name"
],
"exclude": [
"picture_url"
]
},
"query": {
"query_string": {
"query": "双卡"
}
}
}
上面这段入参,就指定了只需要显示 commodity_id
、commodity_name
, 排除掉 picture_url
。