zoukankan      html  css  js  c++  java
  • mongoRepository 支持的所有接口

    与HibernateRepository类似,通过继承MongoRepository接口,我们可以非常方便地实现对一个对象的增删改查,要使
    用Repository的功能,先继承MongoRepository<T, 
    TD>接口,其中T为仓库保存的bean类,TD为该bean的唯一标识的类型,一般为ObjectId。之后在service中注入该接口就可以
    使用,无需实现里面的方法,spring会根据定义的规则自动生成。

    例:

    public interface PersonRepository extends 

    MongoRepository<Person, ObjectId>{ 
    //这里可以添加额外的查询方法 
    } 

    但是MongoRepository实现了的只是最基本的增删改查的功能,要想增加额外的查询方法,可以按照以下规则定义接口的方法。自定义查询方
    法,格式为“findBy+字段名+方法后缀”,方法传进的参数即字段的值,此外还支持分页查询,通过传进一个Pageable对象,返回Page集合。

    例:

    public interface PersonRepository extends 

    MongoRepository<Person, ObjectId>{ 
    //查询大于age的数据 
    public Page<Product> findByAgeGreaterThan(int age,Pageable page) ; 
    } 

    下面是支持的查询类型,每三条数据分别对应:(方法后缀,方法例子,mongodb原生查询语句)

    GreaterThan(大于) 
    findByAgeGreaterThan(int age) 
    {"age" : {"$gt" : age}}

    LessThan(小于) 
    findByAgeLessThan(int age) 
    {"age" : {"$lt" : age}}

    Between(在...之间) 
    findByAgeBetween(int from, int to) 
    {"age" : {"$gt" : from, "$lt" : to}}

    IsNotNull, NotNull(是否非空) 
    findByFirstnameNotNull() 
    {"age" : {"$ne" : null}}

    IsNull, Null(是否为空) 
    findByFirstnameNull() 
    {"age" : null}

    Like(模糊查询) 
    findByFirstnameLike(String name) 
    {"age" : age} ( age as regex)

    (No keyword) findByFirstname(String name) 
    {"age" : name}

    Not(不包含) 
    findByFirstnameNot(String name) 
    {"age" : {"$ne" : name}}

    Near(查询地理位置相近的) 
    findByLocationNear(Point point) 
    {"location" : {"$near" : [x,y]}}

    Within(在地理位置范围内的) 
    findByLocationWithin(Circle circle) 
    {"location" : {"$within" : {"$center" : [ [x, y], distance]}}}

    Within(在地理位置范围内的) 
    findByLocationWithin(Box box) 
    {"location" : {"$within" : {"$box" : [ [x1, y1], x2, y2]}}}

    尽管以上查询功能已经很丰富,但如果还不能满足使用情况的话可以用一下方法---基于mongodb原本查询语句的查询方式。
    例:在原接口中加入

    @Query("{ 'name':{'$regex':?2,'$options':'i'}, sales': {'$gte':?1,'$lte':?2}}") 
    public Page<Product> findByNameAndAgeRange(String name,double ageFrom,double ageTo,Pageable page); 

    注释Query里面的就是mongodb原来的查询语法,我们可以定义传进来的查询参数,通过坐标定义方法的参数。

    还可以在后面指定要返回的数据字段,如上面的例子修改如下,则只通过person表里面的name和age字段构建person对象。 

    @Query(value="{ 'name':{'$regex':?2,'$options':'i'}, sales':{'$gte':?1,'$lte':?2}}",fields="{ 'name' : 1, 'age' : 1}") 
    public Page<Product> findByNameAndAgeRange(String name,double ageFrom,double ageTo,Pageable page);
    ---------------------
    作者:杰克学编程
    来源:CSDN
    原文:https://blog.csdn.net/codeiswhat/article/details/52129782
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    Android源码服务专家(申明:来源于网络)
    Android超精准计步器开发-Dylan计步(申明:来源于网路)
    eclipse中一个项目引用另一个项目的方法(申明:来源于网络)
    javaweb(二十九)——EL表达式
    javaweb学习总结(二十八)——JSTL标签库之核心标签
    javaweb(二十六)——jsp简单标签标签库开发(二)
    javaweb(二十四)——jsp传统标签开发
    javaweb(二十三)——jsp自定义标签开发入门
    javaweb(二十二)——基于Servlet+JSP+JavaBean开发模式的用户登录注册
    javaweb(二十一)——JavaWeb的两种开发模式
  • 原文地址:https://www.cnblogs.com/vana/p/11171755.html
Copyright © 2011-2022 走看看