springboot 整合 mongodb Criteria类 查询条件大全

关于springboot整合mongodb,可查看博文
https://blog.csdn.net/qq_41712271/article/details/116062611

import cn.huawei.JineErpApplication;
import cn.huawei.pojo.Userinfos;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Query;
import java.util.List;

@SpringBootTest(classes = JineErpApplication.class)
public class Test_3 {

    @Autowired
    private MongoTemplate mongoTemplate;

    @Test
    public void fangfa_5() {
        Query query_1 = new Query();
        /*
        $gt:大于
        $lt:小于
        $gte:大于或等于
        $lte:小于或等于
         */
        query_1.addCriteria(Criteria.where("age").gt(586).lt(590));

        /*
        不等于 $ne
         */
        query_1.addCriteria(Criteria.where("age").ne(28));

        //in
        query_1.addCriteria(Criteria.where("roles").in("gen","vip"));

        //not in
        query_1.addCriteria(Criteria.where("roles").nin("gen","vip"));

        /*
        $all和$in类似,但是他需要匹配条件内所有的值 ,【gen, vip, putong】 这种也会返回
         */
        query_1.addCriteria(Criteria.where("roles").all("gen","vip"));

        /*
        取模运算$mod
        如 age % 2 == 0
         */
        query_1.addCriteria(Criteria.where("age").mod(2,0));

        /*
        $size是匹配数组内的元素数量的,如有一个对象:{roles:["gen", "vip", "putong"]},他有3个元素
        官网上说不能用来匹配一个范围内的元素,如果想找$size<5之类的,他们建议创建一个字段来保存元素的数量。
         */
        query_1.addCriteria(Criteria.where("roles").size(3));

        /*
        $exists用来判断一个字段是否存在
         */
        query_1.addCriteria(Criteria.where("address").exists(true));

        /*
        $type 基于 bson type来匹配一个字段的类型
         */
        query_1.addCriteria(Criteria.where("_id").type(JsonSchemaObject.Type.BsonType.OBJECT_ID));

        /*
        查询嵌入对象的值
         */
        query_1.addCriteria(Criteria.where("ename.firstname").is("san"));

        List<Userinfos> userList = mongoTemplate.find(query_1, Userinfos.class, "userinfos");  
    }
}

 

  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值