Mongodb与spring集成 MongoRepository实现增删改查和复杂查询
来源:互联网 发布:mac mysql 命令行登录 编辑:程序博客网 时间:2024/06/05 10:42
与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}} 大于等于用'$gte'表示
LessThan(小于)
findByAgeLessThan(int age)
{"age" : {"$lt" : age}} 小于等于用'$lte'表示
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);
- Mongodb与spring集成(3)------MongoRepository实现增删改查和复杂查询
- Mongodb与spring集成(3)------MongoRepository实现增删改查和复杂查询
- Mongodb与spring集成 MongoRepository实现增删改查和复杂查询
- SSM框架搭建(Spring+SpringMVC+MyBatis)与easyui集成并实现增删改查实现
- SSM框架搭建(Spring+SpringMVC+MyBatis)与easyui集成并实现增删改查实现
- SSM框架搭建(Spring+SpringMVC+MyBatis)与easyui集成并实现增删改查实现
- SSM框架搭建(Spring+SpringMVC+MyBatis)与easyui集成并实现增删改查实现
- SSM框架搭建(Spring+SpringMVC+MyBatis)与easyui集成并实现增删改查实现
- MongoDB 增删改查与 Golang 的语法实现
- MongoDB 增删改查与 Golang 的语法实现
- mongodb整合spring之增删改查
- springboot集成mongodb使用mongoTemplate和MongoRepository
- csharp实现MongoDB的增删改查
- mongodb实现简单的增删改查
- mongodb实现简单的增删改查
- Mongodb-使用javaDriver 实现增删改查
- Java操作MongoDB实现增删改查
- mongodb实现简单的增删改查
- android 数据库 SQLiteOpenHelper
- Angularjs select option 为什么显示问号
- VMware vSphere虚拟化之-组件及用途
- Storyboard 自适应布局
- HTML中Meta标签的作用
- Mongodb与spring集成 MongoRepository实现增删改查和复杂查询
- NYOJ 144 小珂的苦恼(扩展欧几里得)
- zImage文件提取及逆向分析
- Selenium2测试—Selenium+Testng测试环境搭建
- 微信自定义菜单view类型获取openid访问网页
- 豆浆机改装记(1): Android BLE框架
- UILabel,文字添加下划线,中划线
- VBA连接mysql数据库 代码示例
- HIVE分析窗口函数: LAG,LEAD,FIRST_VALUE,LAST_VALUE