Mongodb与spring集成(3)------MongoRepository实现增删改查和复杂查询

2019-03-11 20:17|来源: 网络

 

与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);



转自:http://blog.csdn.net/laigood/article/details/7056093

相关问答

更多
  • 很巧,我公司全部用到了你说的,使用的就是easyui,需要的话回复我
  • 1)在applicationContext里面配置Hibernate的dataSource和SessionFactory 2)编写Dao的 接口是实现类。如果用到 Spring的Hibernate的操作模板(HibernateTemplate)可以继承HibernateDaoSupport,实现类注解成@Repository 3)编写Action,然后注解成@Controller,在Action里面需要用@Autowired注入Dao的 实例 4)配置applicationContext.xml,加上Spr ...
  • 1)在applicationContext里面配置Hibernate的dataSource和SessionFactory 2)编写Dao的接口是实现类。如果用到Spring的Hibernate的操作模板(HibernateTemplate)可以继承HibernateDaoSupport,实现类注解成@Repository 3)编写Action,然后注解成@Controller,在Action里面需要用@Autowired注入Dao的实例 4)配置applicationContext.xml,加上Spring ...
  • 你这个问题有点大了,文字讲解不太好解释通吧,不过我刚做了一个项目,就是使用的ssm,如果需要,可以留下邮箱。
  • 插入一条数据:insert into admin values("admn","admin"); 管理员登录:select * from admin where username="admin" and password="admin"; 如果有数据的话则登陆成功 修改用户名或密码:update admin set username="username" , password="password" where mid=mid 此时管理员已经登陆,可以直接获取到id,根据这个id修改信息 删除:delete ...
  • package com.ly520.db; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.SQLException; import java.sql.Statement; import java.util.Enum ...
  • package com.ly520.db; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.SQLException; import java.sql.Statement; import java.util.Enum ...
  • mysql和SQL标准的增删改查的语句,大部分都是一样,毕竟很多厂商都会按照关系数据库的标准来实现,不过不同的数据库有些会有点不同的。
  • mysql的增删改查语句是怎么写的,跟sql有什么区别,基本没区别,都差不多,特殊的查询有区别。比如限制结果就不是top了,而是limit 3,5(表示从第3条开始取,取5条)之类的。 还有mysql数据库备份跟附加是不是必须要关闭tomcat,这个没必要,直接可以操作,跟TOMCAT无关,不过如果你的程序做过映射,那要重新装载。
  • 插入一条数据:insert into admin values("admn","admin"); 管理员登录:select * from admin where username="admin" and password="admin"; 如果有数据的话则登陆成功 修改用户名或密码:update admin set username="username" , password="password" where mid=mid 此时管理员已经登陆,可以直接获取到id,根据这个id修改信息 删除:delete ...