说说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的集成与使用的更多相关文章

  1. SpringBoot | 第三十一章:MongoDB的集成和使用

    前言 上一章节,简单讲解了如何集成Spring-data-jpa.本章节,我们来看看如何集成NoSQL的Mongodb.mongodb是最早热门非关系数据库的之一,使用也比较普遍.最适合来存储一些非结 ...

  2. SpringBoot12 QueryDSL01之QueryDSL介绍、springBoot项目中集成QueryDSL

    1 QueryDSL介绍 1.1 背景 QueryDSL的诞生解决了HQL查询类型安全方面的缺陷:HQL查询的扩展需要用字符串拼接的方式进行,这往往会导致代码的阅读困难:通过字符串对域类型和属性的不安 ...

  3. spring boot MongoDB的集成和使用

    前言 上一章节,简单讲解了如何集成Spring-data-jpa.本章节,我们来看看如何集成NoSQL的Mongodb.mongodb是最早热门非关系数据库的之一,使用也比较普遍.最适合来存储一些非结 ...

  4. SpringBoot(七):集成DataSource 与 Druid监控配置

    绑定DataSource:Spring Boot默认的数据源是:org.apache.tomcat.jdbc.pool.DataSource,Druid是Java语言中最好的数据库连接池,并且能够提供 ...

  5. spring4与mongodb的集成

    新项目的辅助系统,需要用到mongo系统,今天再次将其使用环境进行了操作搭建.还是遇到一些问题,毕竟之前使用的场景和现在的不同.版本也不一样了. 本次使用的环境: mongo:3.4.4版本 OS: ...

  6. 【第十二章】 springboot + mongodb(复杂查询)

    简单查询:使用自定义的XxxRepository接口即可.(见 第十一章 springboot + mongodb(简单查询)) 复杂查询:使用MongoTemplate以及一些查询条件构建类(Bas ...

  7. DEMO: springboot 与 freemarker 集成

    直接在 DEMO: springboot 与 mybatis 集成 基础上,进行修改. 1.pom.xml 中引用 依赖 <dependency> <groupId>org.s ...

  8. Springboot 和 Mybatis集成开发

    Springboot 和 Mybatis集成开发 本项目使用的环境: 开发工具:Intellij IDEA 2017.1.3 jdk:1.7.0_79 maven:3.3.9 额外功能 PageHel ...

  9. 第十二章 springboot + mongodb(复杂查询)

    简单查询:使用自定义的XxxRepository接口即可.(见 第十一章 springboot + mongodb(简单查询)) 复杂查询:使用MongoTemplate以及一些查询条件构建类(Bas ...

随机推荐

  1. golang 并发模式笔记

    1.并发并不是并行,前者是优先对时间片的抢占,后者是真多核. go中多线程时直接要求并行的方法是: 亦不可滥用,CPU密集型,并发度很高的场景适用. 2.go起的协程 3. function that ...

  2. NOI前的考试日志

    4.14 网络流专项测试 先看T1,不会,看T2,仙人掌???wtf??弃疗.看T3,貌似最可做了,然后开始刚,刚了30min无果,打了50分暴力,然后接着去看T1,把序列差分了一下,推了会式子,发现 ...

  3. Postman-----如何导入和导出

    此处介绍2种导出和导入的操作方法,一种是通过分享link,另一种是导出json文件,再次导入,个人推荐link的方式,简单方便,下面将详细介绍. 第一种:分享链接,导入链接的方式 1.1.生成link ...

  4. Mybatis配置详解

    一.SqlSession的使用范围说明  1.SQLSessionFactoryBuilder   通过SqlSessionFactoryBuilder创建会话工厂SqlSessionFactory, ...

  5. OKHttp源码学习--HttpURLConnection HttpClient OKHttp Get and post Demo用法对比

    1.HttpURLConnection public class HttpURLConnectionGetAndPost { private String urlAddress = "xxx ...

  6. Zabbix-server 3.4 安装详细和修改web界面中文出现的乱码(一)

    1. 老套路先来个Zabbix简介: Zabbix是一个企业级的.开源的.分布式的监控套件: Zabbix可以监控网络和服务的监控状况. Zabbix利用灵活的告警机制,允许用户对事件发送Email. ...

  7. asp.net core系列 45 Web应用 模型绑定和验证

    一. 模型绑定 ASP.NET Core MVC 中的模型绑定,是将 HTTP 请求中的数据映射到action方法参数. 这些参数可能是简单类型的参数,如字符串.整数或浮点数,也可能是复杂类型的参数. ...

  8. Linux-误删apt-get以及把aptitude换回

    误删apt-get拯救我的linux 一.前言 先来说一下apt-get, 这个我们使用linux过程中最常用的命令之一. apt-get是一条linux命令,适用于deb包管理式的操作系统,主要用于 ...

  9. 用Docker解决坑爹的环境搭建系列——mysql:5.6

    sudo docker pull mysql:5.6 mkdir -p /data/docker/mysql/data /data/docker/mysql/logs /data/docker/mys ...

  10. 【原】javascript笔记之Array方法forEach&map&filter&some&every&reduce&reduceRight

    做前端有多年了,看过不少技术文章,学了新的技术,但更新迭代快的大前端,庞大的知识库,很多学过就忘记了,特别在项目紧急的条件下,哪怕心中隐隐约约有学过一个方法,但会下意识的使用旧的方法去解决,多年前ES ...