Java使用mongodb进行数据存储及多表关联,多条件查询

本文记录了在Java Spring Boot项目中使用MongoDB进行数据存储及多表关联查询的过程。通过MongoRepository接口实现数据访问,详细讨论了条件查询、多条件分页查询以及如何构造关联查询语句,旨在解决开发中遇到的类似问题,提供解决方案。
摘要由CSDN通过智能技术生成

前言: 

    在开发的过程中,由于持久层使用的是非关系型数据库mongodb,涉及到列表查询的多表关联查询,在实现此功能的过程中出现了不少问题,做下记录方便以后遇到此类问题可以快速的解决,同时为遇到此类问题的小伙伴提供一点帮助。

    注: Java操作mongodb数据库存储数据,数据访问层需继承 MongoRepository 接口,本实例为Spring boot项目

import org.springframework.data.mongodb.repository.MongoRepository;

public interface TenantRepository extends MongoRepository<Tenant, String> {

}

条件查询

    @RequestMapping(value = "/list", method = RequestMethod.GET)
    @ApiOperation("租户列表")
    public ObjectRestResponse<List<Tenant>> list() {
        Tenant tenant=new Tenant();
        tenant.setDisabled(false);
        Example<Tenant> example = Example.of(tenant);
        List<Tenant> list = tenantRepository.findAll(example);
        return new ObjectRestResponse<List<Tenant>>().data(list);
    }

多条件分页查询

    @RequestMapping(value = "/pageList", method = RequestMethod.GET)
    @ApiOperation("租户分页查询")
    public TableResultResponse pageList(Tenant query) {
        Pageable pageable = PageRequest.of(query.getPage()-1, query.getLimit(), Sort.by(Sort.Direction.DESC,"createTime"));
        //创建匹配器,即如何使用查询条件
        ExampleMatcher matcher = ExampleMatcher.matching() //构建对象
                .withStringMatcher(ExampleMatcher.StringMatcher.CONTAINING) //改变默认字符串匹配方式ÿ
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值