栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

MongoDB的模糊查询

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

MongoDB的模糊查询

springboot  data 整合mongo之后代码模糊查询写法

代码中的方法是自己写的一个查询类。支持链式编程

@Resource
    private MongoTemplate mongoTemplate;


public Order findOrder(Condition condition){

QueryExtension query = new QueryExtension();
     
        query.addCriteria(condition.hasUserId(), Criteria.where("userId").is(condition.getUserId()));
        query.addCriteria(condition.hasUserName(),
            Criteria.where("userName").regex(Pattern.compile(".*" + condition.getUserName() + ".*", Pattern.CASE_INSENSITIVE)));
        query.addCriteria(condition.hasUserMobile(), Criteria.where("userMobile").is(condition.getUserMobile()));


query.addCriteria(condition.hasName(),
            Criteria.where("mallName").regex(Pattern.compile("^.*" + condition.getName() + ".*$", Pattern.CASE_INSENSITIVE)));


//db.order.find({ userName : { $regex : "^.*wang.*$","$options" : "i" } });



return mongoTemplate.find(query, Order.class);
}

 

import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort;
import org.springframework.data.mongodb.core.query.CriteriaDefinition;
import org.springframework.data.mongodb.core.query.Query;

public class QueryExtension extends Query {
    public QueryExtension() {
    }

    public static QueryExtension build() {
        return new QueryExtension();
    }

    public QueryExtension addCriteria(boolean condition, CriteriaDefinition criteriaDefinition) {
        return condition ? (QueryExtension)super.addCriteria(criteriaDefinition) : this;
    }

    public QueryExtension with(boolean condition, Sort sort) {
        return condition ? (QueryExtension)super.with(sort) : this;
    }

    public QueryExtension with(boolean condition, Pageable pageable) {
        return condition ? (QueryExtension)super.with(pageable) : this;
    }
}

官网全部写法

官网地址 :Spring Data MongoDB - Reference documentation 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/678266.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号