前言:
在开发的过程中,由于持久层使用的是非关系型数据库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) //改变默认字符串匹配方式ÿ