springboot~Mongodb的集成与使用
说说springboot与大叔lind.ddd的渊源
Mongodb在Lind.DDD中被二次封装过(大叔的.net和.net core),将它当成是一种仓储来使用,对于开发人员来说只公开curd几个标准的接口即可,而在springboot框架里,它与大叔lind有些类似之处,同样是被二次封装了,开发人员只需要关注自己的业务即可,而标准的curd操作完成由springboot帮助我们来实现,一般地,我们会设计一个与实体对象的接口仓储,让它去继承mongo的标准接口,然后在springboot的依赖注入框架里把标准的实现注入进来,这一切都是框架帮助我们实现的!
在项目中实现mongodb
如果项目需要使用mongodb去持久化数据,一般可以经过下面几个步骤来实现:
1 添加包依赖build.gradle
compile('org.springframework.boot:spring-boot-starter-data-mongodb')
如果有单元测试项目,可以使用内嵌的mongodb,这样它不需要与外部资源进行通信,工作原理:从远程下载mongodb包,启动它,测试完成后删除生成的集合
testCompile('de.flapdoodle.embed:de.flapdoodle.embed.mongo:2.0.3')
2 添加默认的配置项application.yml
spring:
data:
mongodb:
uri: mongodb://192.168.99.100:27017/Test
password: guest
username: guest
3 添加mongodb集合对应的实体类
/**
* 地址.
*/
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Address { /**
* 编号.
*/
@Id
private String id;
/**
* 省.
*/
private String province;
/**
* 市.
*/
private String city;
/**
* 区.
*/
private String district;
/**
* 状态.
*/
private Status status;
}
4 添加实体所对应的仓库类,它需要继承extends标准的mongodb仓储,同时Mongodb仓储支持自动定约定的方法,开发人员可以通过@Query注释来确定返回的字段列表,这对于大数据文档是很必要的,如果默认的接口不能满足我们的要求,我们需要定义个性
化的接口,并去实现它,下面的例子中,我们的AddressExtRepository就是一个个性化接口,我们对外的接口AddressRepository 需要继承它,注意,大叔认为这样破获了面向对象的开闭原则,元芳,你怎么看!
/**
* 对外提供的地址仓储接口,继承所有地址相关的接口.
*/
public interface AddressRepository extends
AddressExtRepository,
MongoRepository<Address, String> { /**
* 根据省,拿地址列表.
*
* @param province
* @return
*/
@Query(fields = "{'province': 0}")
List<Address> findAddressesByProvince(String province); /**
* 根据省和省,拿地址列表.
*
* @param province
* @param city
* @return
*/
@Query()//fields表示包含的字段
List<Address> findAddressesByProvinceAndCityAndDistrict(String province, String city, String district);
}
个性化仓储实现,使用MongoTemplate对象与mongodb数据库进行交互!
/**
* 特殊规则的仓储实现.
*/
public class AddressExtRepositoryImpl implements AddressExtRepository { @Autowired
MongoTemplate mongoTemplate; @Override
public Address findByProvinceAndCity(String province, String city) {
Query query = new Query(Criteria.where("province").is(province).and("city").is(city));
return mongoTemplate.findOne(query, Address.class, "address");
}
}
5 controller中直接通过@Autowired注解来访问仓储和业务对象即可
@RestController
public class MongoController {
// 仓储.
@Autowired
private AddressRepository repository; // 用户业务.
@Autowired
private UserService userService; /**
* 得到地址列表.
*
* @return
*/
@RequestMapping("/address/{province}")
public Address getAddress(@PathVariable("province") String province) {
System.out.println("1,province=" + province);
return userService.getAddress(province);
}
}
感谢各位的阅读!
对知识的探索我们还在继续!
springboot~Mongodb的集成与使用的更多相关文章
- SpringBoot | 第三十一章:MongoDB的集成和使用
前言 上一章节,简单讲解了如何集成Spring-data-jpa.本章节,我们来看看如何集成NoSQL的Mongodb.mongodb是最早热门非关系数据库的之一,使用也比较普遍.最适合来存储一些非结 ...
- SpringBoot12 QueryDSL01之QueryDSL介绍、springBoot项目中集成QueryDSL
1 QueryDSL介绍 1.1 背景 QueryDSL的诞生解决了HQL查询类型安全方面的缺陷:HQL查询的扩展需要用字符串拼接的方式进行,这往往会导致代码的阅读困难:通过字符串对域类型和属性的不安 ...
- spring boot MongoDB的集成和使用
前言 上一章节,简单讲解了如何集成Spring-data-jpa.本章节,我们来看看如何集成NoSQL的Mongodb.mongodb是最早热门非关系数据库的之一,使用也比较普遍.最适合来存储一些非结 ...
- SpringBoot(七):集成DataSource 与 Druid监控配置
绑定DataSource:Spring Boot默认的数据源是:org.apache.tomcat.jdbc.pool.DataSource,Druid是Java语言中最好的数据库连接池,并且能够提供 ...
- spring4与mongodb的集成
新项目的辅助系统,需要用到mongo系统,今天再次将其使用环境进行了操作搭建.还是遇到一些问题,毕竟之前使用的场景和现在的不同.版本也不一样了. 本次使用的环境: mongo:3.4.4版本 OS: ...
- 【第十二章】 springboot + mongodb(复杂查询)
简单查询:使用自定义的XxxRepository接口即可.(见 第十一章 springboot + mongodb(简单查询)) 复杂查询:使用MongoTemplate以及一些查询条件构建类(Bas ...
- DEMO: springboot 与 freemarker 集成
直接在 DEMO: springboot 与 mybatis 集成 基础上,进行修改. 1.pom.xml 中引用 依赖 <dependency> <groupId>org.s ...
- Springboot 和 Mybatis集成开发
Springboot 和 Mybatis集成开发 本项目使用的环境: 开发工具:Intellij IDEA 2017.1.3 jdk:1.7.0_79 maven:3.3.9 额外功能 PageHel ...
- 第十二章 springboot + mongodb(复杂查询)
简单查询:使用自定义的XxxRepository接口即可.(见 第十一章 springboot + mongodb(简单查询)) 复杂查询:使用MongoTemplate以及一些查询条件构建类(Bas ...
随机推荐
- golang 并发模式笔记
1.并发并不是并行,前者是优先对时间片的抢占,后者是真多核. go中多线程时直接要求并行的方法是: 亦不可滥用,CPU密集型,并发度很高的场景适用. 2.go起的协程 3. function that ...
- NOI前的考试日志
4.14 网络流专项测试 先看T1,不会,看T2,仙人掌???wtf??弃疗.看T3,貌似最可做了,然后开始刚,刚了30min无果,打了50分暴力,然后接着去看T1,把序列差分了一下,推了会式子,发现 ...
- Postman-----如何导入和导出
此处介绍2种导出和导入的操作方法,一种是通过分享link,另一种是导出json文件,再次导入,个人推荐link的方式,简单方便,下面将详细介绍. 第一种:分享链接,导入链接的方式 1.1.生成link ...
- Mybatis配置详解
一.SqlSession的使用范围说明 1.SQLSessionFactoryBuilder 通过SqlSessionFactoryBuilder创建会话工厂SqlSessionFactory, ...
- OKHttp源码学习--HttpURLConnection HttpClient OKHttp Get and post Demo用法对比
1.HttpURLConnection public class HttpURLConnectionGetAndPost { private String urlAddress = "xxx ...
- Zabbix-server 3.4 安装详细和修改web界面中文出现的乱码(一)
1. 老套路先来个Zabbix简介: Zabbix是一个企业级的.开源的.分布式的监控套件: Zabbix可以监控网络和服务的监控状况. Zabbix利用灵活的告警机制,允许用户对事件发送Email. ...
- asp.net core系列 45 Web应用 模型绑定和验证
一. 模型绑定 ASP.NET Core MVC 中的模型绑定,是将 HTTP 请求中的数据映射到action方法参数. 这些参数可能是简单类型的参数,如字符串.整数或浮点数,也可能是复杂类型的参数. ...
- Linux-误删apt-get以及把aptitude换回
误删apt-get拯救我的linux 一.前言 先来说一下apt-get, 这个我们使用linux过程中最常用的命令之一. apt-get是一条linux命令,适用于deb包管理式的操作系统,主要用于 ...
- 用Docker解决坑爹的环境搭建系列——mysql:5.6
sudo docker pull mysql:5.6 mkdir -p /data/docker/mysql/data /data/docker/mysql/logs /data/docker/mys ...
- 【原】javascript笔记之Array方法forEach&map&filter&some&every&reduce&reduceRight
做前端有多年了,看过不少技术文章,学了新的技术,但更新迭代快的大前端,庞大的知识库,很多学过就忘记了,特别在项目紧急的条件下,哪怕心中隐隐约约有学过一个方法,但会下意识的使用旧的方法去解决,多年前ES ...