Spring + Spring Boot + MyBatis + MongoDB的整合教程

前言

我之前是学Spring MVC的,后面听同学说Spring Boot挺好用,极力推荐我学这个鬼。一开始,在网上找Spring Boot的学习资料,他们博文写得不是说不好,而是不太详细。

我就在想我要自己写一篇尽可能详细的文章出来,下面话不多说了,来一看看详细的介绍吧。

技术栈

  • Spring
  • Spring Boot
  • MyBatis
  • MongoDB
  • MySQL

设计模式

MVC

功能

  • 注册(用户完成注册后是默认未激活的,程序有个定时器在检测没有激活的用户,然后发一次邮件提醒用户激活)
  • 登录
  • 发帖(帖子存在MongoDB)
  • 评论
  • 其他功能正在添加中...

编辑器

IntellJ IDEA 2017

目录结构


正文

第一步先让我们创建项目吧,打开idea File -> New -> Project。我们是创建Spring Boot项目,所以来到Project这一步是选Spring Initailizr,选好jdk再点next。

然后就来到了一下这个界面,这里是让你填写项目的目录,你喜欢就ok。

接下来就是让你选择需要那些依赖,要把那个Web,MyBaits,MongoDB,数据库(我用的是mysql,所以我勾选了mysql)这些勾选上。

最后是填写项目名字,然后点Finish就完成创建了。

如何整合Spring+SpringBoot+MyBatis+MongoDB

在第一步中,你填的项目目录下,我喜欢建个文件夹叫做Controller,当然用来放Controller了,Entity文件夹放实体类,Service文件是存放业务逻辑层,这个文件下还有ServiceImpl文件夹对应的是存放Service的实现类。

第二步配置,详细的代码我已经 放在github上了 点击跳转到github  (本地下载)。我们的配置写在一个叫做application.yml文件里。你们新建的项目是默认是application.properties文件,但是.yml文件配置起来比.properties文件简洁,所以个人比较喜欢.yml文件。

怎么个简洁法,对比一下你就知道了。.properties配置起来是这样的(这里用配置发送邮件为例子)

spring.mail.host=smtp.qq.com
spring.mail.username=用户名
spring.mail.password=密码
spring.mail.properties.mail.smtp.auth=true
spring.mail.properties.mail.smtp.starttls.enable=true
spring.mail.properties.mail.smtp.starttls.required=true

而.yml配置起来是这样的:

mail:
 host: smtp.qq.com
 username: //用来发送邮件的账号
 password: //这里是IMAP/SMTP服务的授权密码
 properties:
 mail:
 stmp:
  auth: true
  starttls:
  enable: true
  required: true
 port: 587

配置数据源(数据源、MongoDB还有mail都是在spring下),

spring:
 datasource:
 url: jdbc:mysql://localhost:3306/blog?useUnicode=true&characterEncoding=utf-8&useSSL=false
 username: root
 password: root
 driver-class-name: com.mysql.jdbc.Driver
 platform: mysql
 jpa:
 show-sql: true
 data:
 mongodb:
 uri: mongodb://localhost:27017/blog //blog记得换成你取的名字

配置MyBaits,它在.yml和spring地位一样高,所以mybatis,spring缩进是一样的。

mybatis:
 type-aliases-package: com.example.junior.Entity //这里是实体类所在的包
 mapper-locations: classpath:/mapper/*.xml //这里是放sql语句的映射文件

还有一个值得注意的地方是JuniorApplication.java,它不仅仅是启动引导类,还是个配置类。所以有一些配置需要写在这里面。

@SpringBootApplication
@EnableTransactionManagement
@EnableCaching
@EnableScheduling //我有个定时器,这个注解是让它发现定时器
@MapperScan(basePackages = "com.example.junior.Dao") //让它去发现你的Dao层
public class JuniorApplication {
 public static void main(String[] args) {
 SpringApplication.run(JuniorApplication.class, args);
 }
}

如果你在创建项目的时候,忘记勾选某一些依赖的话不要紧,可以在pom.xml文件里添加依赖。添加完成后在pom.xml右键 点击 Maven -> Reimport就Ok了

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

(0)

相关推荐

  • Spring Boot 集成MyBatis 教程详解

    Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者. 在集成MyBatis前,我们先配置一个druid数据源. Spring Boot 系列 1.Spring Boot 入门 2.Spring Boot 属性配置

  • Spring Boot 集成Mybatis实现主从(多数据源)分离方案示例

    本文将介绍使用Spring Boot集成Mybatis并实现主从库分离的实现(同样适用于多数据源).延续之前的Spring Boot 集成MyBatis.项目还将集成分页插件PageHelper.通用Mapper以及Druid. 新建一个Maven项目,最终项目结构如下: 多数据源注入到sqlSessionFactory POM增加如下依赖: <!--JSON--> <dependency> <groupId>com.fasterxml.jackson.core<

  • springboot与mybatis整合实例详解(完美融合)

    简介 从 Spring Boot 项目名称中的 Boot 可以看出来,Spring Boot 的作用在于创建和启动新的基于 Spring 框架的项目.它的目的是帮助开发人员很容易的创建出独立运行和产品级别的基于 Spring 框架的应用.Spring Boot 会选择最适合的 Spring 子项目和第三方开源库进行整合.大部分 Spring Boot 应用只需要非常少的配置就可以快速运行起来. Spring Boot 包含的特性如下: 创建可以独立运行的 Spring 应用. 直接嵌入 Tomc

  • 详解Spring Boot整合Mybatis实现 Druid多数据源配置

    一.多数据源的应用场景 目前,业界流行的数据操作框架是 Mybatis,那 Druid 是什么呢? Druid 是 Java 的数据库连接池组件.Druid 能够提供强大的监控和扩展功能.比如可以监控 SQL ,在监控业务可以查询慢查询 SQL 列表等.Druid 核心主要包括三部分: 1. DruidDriver 代理 Driver,能够提供基于 Filter-Chain 模式的插件体系. 2. DruidDataSource 高效可管理的数据库连接池 3. SQLParser 当业务数据量达

  • Spring Boot整合MyBatis操作过程

    1.加入mybatis-spring-boot-stater的Maven依赖 <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.1.1</version> </dependency> 2.配置数据源 在src/main/re

  • 详解Spring Boot集成MyBatis(注解方式)

    MyBatis是支持定制化SQL.存储过程以及高级映射的优秀的持久层框架,避免了几乎所有的JDBC代码和手动设置参数以及获取结果集.spring Boot是能支持快速创建Spring应用的Java框架.本文通过一个例子来学习Spring Boot如何集成MyBatis,而且过程中不需要XML配置. 创建数据库 本文的例子使用MySQL数据库,首先创建一个用户表,执行sql语句如下: CREATE TABLE IF NOT EXISTS user ( `id` INT(10) NOT NULL A

  • springboot + mybatis配置多数据源示例

    在实际开发中,我们一个项目可能会用到多个数据库,通常一个数据库对应一个数据源. 代码结构: 简要原理: 1)DatabaseType列出所有的数据源的key---key 2)DatabaseContextHolder是一个线程安全的DatabaseType容器,并提供了向其中设置和获取DatabaseType的方法 3)DynamicDataSource继承AbstractRoutingDataSource并重写其中的方法determineCurrentLookupKey(),在该方法中使用Da

  • Spring Boot MyBatis 连接数据库配置示例

    最近比较忙,没来得及抽时间把MyBatis的集成发出来,其实mybatis官网在2015年11月底就已经发布了对SpringBoot集成的Release版本,示例代码:spring-boot_jb51.rar 前面对JPA和JDBC连接数据库做了说明,本文也是参考官方的代码做个总结. 先说个题外话,SpringBoot默认使用 org.apache.tomcat.jdbc.pool.DataSource 现在有个叫 HikariCP 的JDBC连接池组件,据说其性能比常用的 c3p0.tomca

  • Spring Boot 与 mybatis配置方法

    1.首先,spring boot 配置mybatis需要的全部依赖如下: <!-- Spring Boot 启动父依赖 --> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.1.RELEASE</version> </

  • 详解SpringBoot和Mybatis配置多数据源

    目前业界操作数据库的框架一般是 Mybatis,但在很多业务场景下,我们需要在一个工程里配置多个数据源来实现业务逻辑.在SpringBoot中也可以实现多数据源并配合Mybatis框架编写xml文件来执行SQL.在SpringBoot中,配置多数据源的方式十分便捷, 下面开始上代码: 在pom.xml文件中需要添加一些依赖 <!-- Spring Boot Mybatis 依赖 --> <dependency> <groupId>org.mybatis.spring.b

随机推荐