//查询是否选择全省
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,即可查询出自己需要的数据