mongodb和mongoTemplate复杂条件查询 (or与and)

 

 

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/tjbsl/article/details/80620303

使用Mongodb查询需要拼接复杂的or和and参数

MongoDb有表格:

1

"state1" : 11,

"state2" : 21,

"value" : 100

2

"state1" : 11,

"state2" : 22,

"value" : 300

3

"state1" : 11,

"state2" : 22,

"value" : 200

4

"state1" : 12,

"state2" : 21,

"value" : 300

 

要实现管理数据的如下SQL形式:

关系数据库:select * from where(state1=11 and state2=22) or value >300

首先使用MongoDB的方式查询:

分为以下几个步骤实现:

步骤一:实现 (state1=11 and state2=22)

db.getCollection('testOrAnd').find(

{$and:[{"state1":11},{"state2":22}]}

)

步骤二:使用or形式实现 value >300

db.getCollection('testOrAnd'). find(

{ $or:[{"value":{$gte:300}}] }

)

步骤三:将步骤一参数拼接到步骤二or条件

db.getCollection('testOrAnd').

find({$or:

[

{$and:[{"state1":11},{"state2":22}]},{"value":{$gte:300}}

]

})

 

最终实现结果:

 

使用spring-mongotemplate的方式查询(Criteria.where是静态方法):

分析查询方式,类似使用client的分析方式,分为以下几个步骤实现:

步骤一:实现 (state1=11 and state2=22)

query.addCriteria(

new Criteria().andOperator(

Criteria.where("state1").is(11),

Criteria.where("state2").is(22)

)

);

步骤二:使用or形式实现 value >300

query.addCriteria(

new Criteria().orOperator(

Criteria.where("value").gte(300)

)

);

步骤三:将步骤一参数拼接到步骤二or条件

query.addCriteria(

new Criteria().orOperator(

Criteria.where("value").gte(300),

new Criteria().andOperator(

Criteria.where("state1").is(11),

Criteria.where("state2").is(22)

)

)

);

 

升级查询,实际场景中要根据传输的参数是否为空,拼接查询条件:

(1)如果最外层是and关系(query.add多个creterria默认为and关系)

if(条件){

query.addCriteria(Criteria.where);

}

if(条件){

query.addCriteria(Criteria.where);

}

if(条件){

query.addCriteria(Criteria.where);

}

默认拼接的query条件为and形式。

(1)如果最外层是or关系(目前只想到此笨方法)

//1.拼接参数

Criteria operator1=null;

Criteria operator2=null;

if(1==1){//模拟判断条件

operator1 = new Criteria().andOperator(

Criteria.where("state1").is(11),

Criteria.where("state2").is(22)

);

}

if(1==1){//模拟判断条件

operator2 = Criteria.where("value").gte(300);

}

//2.判断参数

if(operator1!=null && operator2!=null){

query.addCriteria(new Criteria().orOperator(operator1,operator2));

}else if(operator1!=null){

query.addCriteria(operator1);

}else if(operator2!=null){

query.addCriteria(operator2);

}

 

补充:多个条件直接查询,默认是and形式

db.getCollection('testOrAnd').find({"state1":11,"state2":22})

  • 6
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值