mongo- spring boot 操作- and or查询

文章介绍了如何在MongoDB中使用SpringBoot进行复杂的and/or查询操作,包括Java代码示例,展示了如何构建查询条件来筛选address为上海,年龄大于10,以及name或nickName为小明的用户记录。

mongo- spring boot 操作- and or查询

场景

select * from user where address="上海" age >10 and (name="小明" or nickName like '小明')

以前查询在 mongo 实现

{
	"address": "上海",
	"$and": [{
		"$or": [{
			"name": "小明"
		}, {
			"nickName": "小明"
		}]
	}],
	"name": 2
}

java 实现

@Override
public List<User> userList(ArticleAppQuery articleAppQuery) {
    Criteria criteria = new Criteria();
    criteria.and("age").gt(10);
    Criteria tmp= new Criteria();
    Criteria criteria1 = Criteria.where("name").is("小明");
    Criteria criteria2 = Criteria.where("nickName").is("小明");
    criteria.andOperator(tmp.orOperator(criteria1,criteria2));
    criteria.and("address").is("上海"); 
    Query query = new Query(criteria);
    query.with(Sort.by(Sort.Order.desc("createTo,e")));
    return mongoTemplate.find(query,User.class);
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值