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

本文记录了在Spring Boot项目中使用Java操作MongoDB进行数据存储,包括多表关联查询和多条件分页查询的实现过程。通过MongoRepository接口进行数据操作,使用Example和ExampleMatcher进行条件匹配,以及聚合操作实现复杂查询。同时,展示了如何进行数据的新增、修改、删除等基本操作。
摘要由CSDN通过智能技术生成

前言:

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

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

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

public interface TenantRepository extends MongoRepository{

}

条件查询

@RequestMapping(value = "/list", method = RequestMethod.GET)

@ApiOperation("租户列表")

public ObjectRestResponse> list() {

Tenant tenant=new Tenant();

tenant.setDisabled(false);

Exampleexample = Example.of(tenant);

Listlist = tenantRepository.findAll(example);

return new ObjectRestResponse>().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) //改变默认字符串匹配方式:模糊查询

.withIgnoreCase(true) //改变默认大小写忽略方式

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Spring Data MongoDB 中,可以使用 Aggregation Framework 来进行多表分组。下面是一个示例: 假设我们有两个集合,一个是 orders,另一个是 customers,orders 集合中有一个字段 customer_id,示订单所属的客户。现在我们想要按照客户性别统计他们的订单数量。可以使用以下代码实现: ```java import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.aggregation.Aggregation; import org.springframework.data.mongodb.core.aggregation.Fields; import org.springframework.data.mongodb.core.aggregation.LookupOperation; import org.springframework.data.mongodb.core.query.Criteria; import org.springframework.stereotype.Repository; import java.util.List; @Repository public class OrderRepositoryImpl implements OrderRepositoryCustom { private final MongoTemplate mongoTemplate; public OrderRepositoryImpl(MongoTemplate mongoTemplate) { this.mongoTemplate = mongoTemplate; } @Override public List<OrderCountByGender> countOrdersByGender() { LookupOperation lookupOperation = LookupOperation.newLookup() .from("customers") .localField("customer_id") .foreignField("_id") .as("customer"); Aggregation aggregation = Aggregation.newAggregation( lookupOperation, Aggregation.project("customer.gender"), Aggregation.group("customer.gender").count().as("count"), Aggregation.project(Fields.fields("count")).and("gender").previousOperation() ); return mongoTemplate.aggregate(aggregation, "orders", OrderCountByGender.class).getMappedResults(); } } ``` 其中 OrderCountByGender 是一个 POJO 类,用于存储按照性别统计的订单数量: ```java public class OrderCountByGender { private String gender; private Long count; // getters and setters } ``` 在上面的代码中,我们使用 LookupOperation 将 orders 集合中的 customer_id 与 customers 集合中的 _id 关联起来。然后,使用 Aggregation 进行分组统计,最后使用 mongoTemplate.aggregate 方法执行聚合操作,并将结果映射到 OrderCountByGender 类型的对象列中返回。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值