java实现mongodb的模糊查询


public Result<List<Code>> getCodes(@RequestParam(required = false) String name, @RequestHeader(required = false) HttpHeaders headers)
{

Query query = new Query();

Criteria criteria = new Criteria();
name = name.trim();
if(name.equals("") || name.equals(null)){
criteria.and("name").is(name);
}else{
Criteria name= new Criteria();
name.and("name").regex("^.*" +name+ ".*$");
Criteria value= new Criteria();
value.and("value").regex("^.*" +name+ ".*$");

criteria.orOperator(name,value);//查询条件or
}

query.addCriteria(criteria);

//根据name和code进行模糊查询
//db.getCollection('code').find({"$or":[{"code" : /GM/},{"value":/感冒/}]})

//db.getCollection('code').find({ "$or" : [ { "name" : { "$regex" : "^.*感冒.*$"}} , { "value" : { "$regex" : "^.*感冒.*$"}}]}).sort({"value":1})
List<Code> codes = mongoTemplate.find(query,Code.class, "code");

return new Result<List<Code>>("0", "查询成功", codes );
}


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM