spring集成mongoTemplate 一些应用场景的用法

来源:互联网 发布:宠物小精灵是什么软件 编辑:程序博客网 时间:2024/06/06 11:04

最近在工作中第一次用到了mongodb 没来得及很深的去学习他的原理,先记录一下spring中集成的mongoTemplate一些方法的使用。


1.查询全部的collection中的document


其中new Query()是查询条件 这里是查询全部 所以没有拼查询条件; IntegrationUser.class是返回的class类型,USER是在类中定义的Collection的名字 下同


2.带查询条件的 查询




这里建议去用 QueryBuilder 去拼接查询条件  如果实体类中的还有实体类(比如图中的operator包含candidateUsers,candidateUser中包含adminId) 就如图中的调用。


3.插入或更新 操作



4.带排序查询




5.分页模糊查询  


在做列表页的分页操作时  经常会用到模糊查询 :

@Overridepublic PageModel<TaskPlan> findTaskPlanList(QueryTaskPlanListRequestDto queryTaskPlanListRequestDto) {PageModel<TaskPlan> pageModel = new PageModel<TaskPlan>();// 计算查询limit参数Integer pageNo = queryTaskPlanListRequestDto.getPageNo() == null ? 1 : queryTaskPlanListRequestDto.getPageNo();Integer pageSize = queryTaskPlanListRequestDto.getPageSize() == null ? 10: queryTaskPlanListRequestDto.getPageSize();// 获取所有字段Field[] declaredFields = QueryTaskPlanListRequestDto.class.getDeclaredFields();QueryBuilder queryBuilder = new QueryBuilder();// 循环设置查询条件try {for (Field field : declaredFields) {// 不为空设置进去查询条件 这里是查总记录数field.setAccessible(true);// 设置反射可以得到私有字段String name = field.getName();Object object = field.get(queryTaskPlanListRequestDto);if (null == object || name.equals("pageNo") || name.equals("pageSize")) {continue;}if ("taskName".equals(name)) {// 模糊查询queryBuilder.and(name).regex(Pattern.compile("^.*" + String.valueOf(object) + ".*$"));} else {queryBuilder.and(name).is(object);}}} catch (Exception e) {LOG.error("findTaskPlanList error : {}", e);}DBObject dbObject = queryBuilder.get();// 总记录数long count = mongoTemplate.count(new BasicQuery(dbObject), TASKPLAN);// 总页数long totalPages = ((count + pageSize - 1) / pageSize);Integer skip = (pageNo - 1) * pageSize;List<TaskPlan> find = mongoTemplate.find(new BasicQuery(dbObject).skip(skip).limit(pageSize).with(new Sort(Direction.DESC, "updateTime")),TaskPlan.class, TASKPLAN);pageModel.setList(find);pageModel.setPageNo(pageNo);pageModel.setPageSize(pageSize);pageModel.setTotalPages(totalPages);pageModel.setTotalRecords(count);return pageModel;}