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