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

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


1.查询全部的collection中的document


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


2.带查询条件的 查询




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


3.插入或更新 操作



4.带排序查询




5.分页模糊查询  


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

	@Override
	public 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;
	}
    







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值