SpringBoot 整合 MongoDB:高级查询篇

上一篇文章,我们讲了如何使用 SpringBoot 整合 MongoDB 实现简单的 CRUD。本文将带你深入了解如何使用 Spring Data MongoDB 执行高级查询,Spring Data MongoDB 为操作 MongoDB 数据库提供了强大的支持,简化了数据访问层的开发工作,接下来我们将结合实际案例,逐步讲解如何构建灵活的查询语句。

1. Spring Data MongoDB 查询基础

在深入高级查询之前,让我们先回顾一下 Spring Data MongoDB 的基本查询方法。

1.1 使用方法名进行查询

Spring Data MongoDB 允许你直接使用方法名来定义简单的查询。例如,要查找所有 name 为 "张三" 的用户:

public interface UserRepository extends MongoRepository<User, String> {
    List<User> findByName(String name);
}

1.2 使用 @Query 注解进行查询

对于更复杂的查询,可以使用 @Query 注解来自定义查询语句。例如,要查找年龄大于 18 岁的用户:

public interface UserRepository extends MongoRepository<User, String> {
    @Query("{ 'age' : { $gt: ?0 } }")
    List<User> findByAgeGreaterThan(int age);
}

2. 高级查询详解

2.1 复杂条件查询

2.1.1 使用逻辑运算符

可以使用 $and$or$not 等逻辑运算符来组合多个查询条件。例如,要查找 name 为 "张三" 且年龄大于 18 岁的用户:

@Query("{$and: [{'name': ?0}, {'age': {$gt: ?1}}]}")
List<User> findByNameAndAgeGreaterThan(String name, int age);
2.1.2 使用范围查询

可以使用 $gt$gte$lt$lte 等运算符进行范围查询。例如,要查找年龄在 18 到 30 岁之间的用户:

@Query("{ 'age' : { $gt: ?0, $lt: ?1 } }")
List<User> findByAgeBetween(int startAge, int endAge);

2.2 使用 Projections

Projections 允许你指定要返回的字段,避免查询不需要的数据,提高查询效率。

Repository
@Query(value = "{}", fields = "{ 'name' : 1, 'age' : 1, 'id' : 0 }")
    List<userVo> findAllNamesAndAges();
Vo
import com.fasterxml.jackson.annotation.JsonProperty;

public class userVo {

    @JsonProperty("name")
    private String name;

    @JsonProperty("age")
    private int age;

    // 省略 getter 和 setter 方法
}

2.3 使用 Criteria 进行动态查询

Criteria 类提供了更灵活的查询条件构建方式,可以根据业务逻辑动态拼接查询条件。

public List<User> query(@RequestParam String name, @RequestParam int minAge,  @RequestParam int maxAge) {
        // 两种写法看个人喜好,效果一样

        // 写法一
//        Criteria criteria = new Criteria();
//        criteria.and("name").regex(name);
//        criteria.and("age").gt(age1).lt(age2);
//        return mongoTemplate.find(new Query(criteria), User.class);

        // 写法二
        Query query = new Query();
        query.addCriteria(Criteria.where("name").regex(name));
        query.addCriteria(Criteria.where("age").gt(age1).lt(age2));
        return mongoTemplate.find(query, User.class);
    }
Criteria 基本比较操作符
操作符说明示例
is等于criteria.and("name").is("张三")
ne不等于criteria.and("age").ne(18)
gt大于criteria.and("age").gt(18)
gte大于等于criteria.and("age").gte(18)
lt小于criteria.and("age").lt(30)
lte小于等于criteria.and("age").lte(30)
in包含在列表中criteria.and("city").in(Arrays.asList("北京", "上海"))
nin不包含在列表中criteria.and("city").nin(Arrays.asList("广州", "深圳"))
Criteria 逻辑运算符
  • and:多个条件同时满足

    criteria.and("name").is("张三").and("age").gt(18);

  • or:多个条件中至少一个满足

    criteria.orOperator(Criteria.where("name").is("张三"), Criteria.where("age").gt(30));​​​​​​​

  • not:不满足条件

    criteria.and("city").not().is("北京"); 
    Criteria 数组操作符
  • all:匹配数组中所有元素

    criteria.and("hobbies").all(Arrays.asList("reading", "music"));s
  • size:匹配数组长度

    criteria.and("hobbies").size(3);
    Criteria 元素操作符
  • exists:判断字段是否存在

    criteria.and("email").exists(true);
  • type:判断字段类型

    criteria.and("age").type(Type.NUMBER);
  • Criteria 正则表达式
criteria.and("name").regex("张");

  • 57
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot整合MongoDB的详细步骤如下: 1. 首先,在项目的pom.xml文件中添加MongoDB的Maven依赖项。可以使用以下坐标引入MongoDB依赖: ``` <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> </dependencies> ``` 2. 在项目的application.yml或application.properties文件中配置MongoDB的连接信息。可以使用以下格式配置MongoDB的URI: ``` spring: data: mongodb: uri: mongodb://ip地址:27017/数据库名 ``` 如果MongoDB需要用户名和密码进行验证,可以使用以下格式配置MongoDB的URI: ``` spring: data: mongodb: uri: mongodb://用户名:密码@ip地址:27017/数据库名 ``` 3. 在代码中使用MongoTemplate进行MongoDB的操作。首先需要在需要使用MongoTemplate的类中注入MongoTemplate实例,可以使用@Autowired注解注入: ``` @Autowired private MongoTemplate mongoTemplate; ``` 4. 可以使用MongoTemplate进行基本的增删改查操作。例如,可以使用save()方法保存文档到MongoDB集合中: ``` Book book = new Book(); book.setId(10); book.setName("testMongoDB"); book.setType("testMongoDB"); book.setDescription("testMongoDB"); mongoTemplate.save(book); ``` 5. 可以使用MongoTemplate进行细节查询,例如复杂查询、分页和排序。可以使用find()方法和Query对象进行查询,如下所示: ``` List<Book> result = mongoTemplate.find(new Query(Criteria.where("字段").is("值")), Book.class); ``` 其中,"字段"是需要查询的字段名,"值"是需要查询的值,Book.class是需要查询的实体类。 这些是Spring Boot整合MongoDB的基本步骤,通过配置和使用MongoTemplate,可以方便地进行MongoDB的操作和查询。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [springboot整合mongoDb](https://blog.csdn.net/z_hy2018/article/details/131227442)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [springboot整合mongodb changestream代码](https://download.csdn.net/download/zhangcongyi420/82033169)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

missterzy

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

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

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

打赏作者

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

抵扣说明:

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

余额充值