Spring Data MongoDB 多个条件或查询

本文介绍如何使用MongoDB的Criteria和Query进行复杂条件匹配,包括全省、全市及具体省市区的数据查询,通过orOperator实现条件的逻辑或操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 //查询是否选择全省
        Criteria c1 = Criteria.where("relationOrgProductsScope").elemMatch(Criteria.where("seriesId").is(seriesId).and("provinceId").is(provinceId)
                .and("cityId").is(0).and("districtId").is(provinceId)).and("disabled").is(0);
 //查询选择全市
        Criteria c2 = Criteria.where("relationOrgProductsScope").elemMatch(Criteria.where("seriesId").is(seriesId).and("provinceId").is(provinceId)
                .and("cityId").is(cityId).and("districtId").is(cityId)).and("disabled").is(0);
 //查询具体的省,市,区
        Criteria c3 = Criteria.where("relationOrgProductsScope").elemMatch(Criteria.where("seriesId").is(seriesId).and("provinceId").is(provinceId)
                .and("cityId").is(cityId).and("districtId").is(districtId)).and("disabled").is(0);
        Criteria cr = new Criteria();
        Query query = new Query(cr.orOperator(c1,c2,c3));
        return mongoTemplate.findOne(query, OrgProductsScopeDto.class);

c1表示选择全省的数据,例如全陕西省数据

c2表示选择全市的数据   例如全陕西省西安市数据

c3表示选择具体的省,市,区数据 例如陕西省西安市雁塔区

这三者之间的关系是或的关系,满足任何一个条件即可

通过cr把c1,c2,c3合并成一个Criteria,封装成一个Query,即可查询出自己需要的数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值