springboot 整合mongoTemplate的 Query Criteria 用法

1.通过注解注入 mongoTemplate

@Autowired
private MongoTemplate mongoTemplate;

2.获取Query 和  Criteria 对象

 Query query = new Query();
 Criteria criteria = new Criteria();

3.多参数动态查询。criteria 有两种写法,一种是criteria.and().is();另一种是criteria.where().is(),两种方式不能混合使用,否则不生效。

if(runningStatus != null){
criteria.and("runningStatus").is(runningStatus);
}

4.根据日期时间进行范围查询

SimpleDateFormat format =  new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" );
		
criteria.and("createTime").gt(format.parse(createTime));
criteria.and("endTime").lte(format.parse(endTime));

5.模糊查询

Pattern pattern=Pattern.compile("^.*"+taskTypeCode+".*$", Pattern.CASE_INSENSITIVE);
criteria.and("taskTypeCode").regex(pattern);

6.将查询条件装载到query中

query.addCriteria(criteria);

7.排序 通过参数 sord 判断排序方向,sortBy 为排序字段

 query.with(new Sort(sord.length() == 3 ? Direction.ASC : Direction.DESC, sortBy));

8.分页,有两种方式,一种是通过pageable 一种是 limit().skip();limit表示查询多少数据,skip表示从哪条数据查起

//第一种
  query.with(pageable);
 long totoal = this.mongoTemplate.count(query, TaskMongo.class);
 List listTaskMongo = this.mongoTemplate.find(query , TaskMongo.class);

//第二种
  query.limit(5000).skip(5000);
  List listTaskMongo = this.mongoTemplate.find(query , TaskMongo.class);

9.一个模糊关键字匹配多个字段

 Pattern pattern=Pattern.compile("^.*"+pattern_name+".*$", Pattern.CASE_INSENSITIVE);
            criatira.orOperator(Criteria.where("name").regex(pattern),
                    Criteria.where("sex").regex(pattern),
                    Criteria.where("age").regex(pattern),
                    Criteria.where("class").regex(pattern));

10. 查询指定的字段通过 Field这个类,通过findFields.include()方法设置查询字段

Query query = new Query(criteria);
Field findFields = query.fields();
findFields.include("id");

 

 

 

 

你可能感兴趣的:(Java)