elasticesearch nested多条件多嵌套查询

索引映射结构

"properties": {

                "attrs": {

                    "type": "nested",

                    "properties": {

                        "attrId": {

                            "type": "long"

                        },

                        "attrName": {

                            "type": "keyword",

                        },

                        "attrValue": {

                            "type": "keyword",

                        }

                    }

                },

                ....

}

 导入数据

例如某一条数据拥有的属性attrs列表如下

 需求: 通过多个属性对象(attrId,attrValue)查询同时拥有这些属性对象的目标数据

 思路:构建bool查询,过滤或must多个nested嵌套查询,这里需要多个nested是因为一个nested嵌套查询时匹配到的属性对象为单个闭区间,无法访问到其余属性对象。

错误的方式如下:

 

 

 正确的请求:

json 请求实现

{
    "query":{
	"bool": {
		"filter": [{
            "nested": {
				"path": "attrs",
				"query": {
					"bool": {
						"must": [
                            {"term": {"attrs.attrId": {"value": 34}}},
                            {"term":{"attrs.attrValue": {"value": "培根"}}}
                        ]
					}
				},
				"score_mode": "none"
	        }},
            {
			"nested": {
				"path": "attrs",
				"query": {
					"bool": {
						"must": [
                            {"term": { "attrs.attrId": {"value": 41}}},
                            {"term":{"attrs.attrValue": {"value": "上海外语教育出版社"}}}
                        ]
					}
				},
				"score_mode": "none"
			}
		}]
	}
}}

      数据查询成功

java api 实现

if(attrs!=null && attrs.size()>0){
    for(String attr : attrs){
        BoolQuery.Builder attrValueBoolBuilder=new BoolQuery.Builder();
        String[] attrSplit=attr.split("_");
        String attrId = attrSplit[0];
        String attrValue = attrSplit[1];
        attrValueBoolBuilder.must(m->m
                .term(t->t
                        .field("attrs.attrId").value(Long.parseLong(attrId))
                )
        );
        attrValueBoolBuilder.must(m->m
                .term(t->t
                    .field("attrs.attrValue").value(attrValue)
            )
        );
        NestedQuery nestedQuery=NestedQuery.of(n->n
                .path("attrs")
                .scoreMode(ChildScoreMode.None)
                .query(q->q.bool(attrValueBoolBuilder.build())));

        boolQueryBuilder.filter(f->f.nested(nestedQuery));
    }
}
searchRequestBuilder.query(q->q.bool(boolQueryBuilder.build()));

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

菠萝追雪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值