Spring boot学习(三) Spring boot整合mybatis

前言

前面我们介绍了如何创建一个Spring boot项目以及Spring boot项目的一些基本配置,在了解了这些知识的前提下本篇博客继续介绍在Spring boot中配置一个基于java的持久层框架---Mybatis

文章首发于个人博客:【http://www.xiongfrblog.cn

为什么使用Mybatis

在实际的开发过程中是离不开数据库的,这里指的是关系型数据库,例如MySqlOracle,SqlServer等。大家应该都清楚如果不使用任何框架的情况下,我们项目要想连接数据库大致分为以下步骤:

  1. 加载驱动(使用不同的数据库加载不同的驱动)
  2. 获取连接
  3. 编写sql
  4. 创建statement
  5. 执行sql语句并处理结果
  6. 从下而上依次关闭连接

实际的开发过程中,我们对数据库的操作是很频繁的,如果都按照上边的方式去连接数据库的话,将会给我们带来很糟糕的体验,所以Mybatis应运而生,Mybatis内部封装了jdbc,使我们开发者只需要考虑sql语句的编写,其余的都帮我们搞定,极大的减轻了开发人员的工作量,而且还提供了动态sql等强大功能,能应对实际项目中的各种需求,这也是它受到大家青睐的原因。

在Spring boot中配置Mybatis

添加依赖

在整合Mybatis之前先准备一个干净的Spring boot项目,然后在pom.xml文件中添加mybatis-spring-boot-starter依赖,因为需要关联到数据库,所以还必须添加一个数据库的依赖,这里我使用的是Mysql数据库,所以需要在pom.xml文件中添加以下两个依赖:

<!-- 整合mysql -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>
<!-- 整合mybatis -->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.2</version>
</dependency>

不同的Spring boot版本对应的Mybatis也不一样,详细情况可查阅官方文档【传送门】。

看到网上很多教程都添加了jdbc的依赖,其实这里是不需要的,因为mybatis-spring-boot-starter已经包含了spring-boot-starter-jdbc依赖,查看项目中隐形依赖的方法为(使用eclipse):右键项目-->Run As-->Maven build...在弹出框的Goals栏中输入dependency:tree,点击Run,在控制台就会打印出项目的所有依赖及关系,如图:

在这里插入图片描述

图示内容可以证明我上面的言论。

配置数据源

application.properties配置文件中添加如下内容:

#mybatis配置
#配置实体类的位置
mybatis.type-aliases-package=com.web.springbootmybatis.entity
#xml文件位置
mybatis.mapper-locations=classpath:mapper/*.xml
#mysql数据库连接信息配置
#mysql驱动
spring.datasource.driverClassName=com.mysql.jdbc.Driver
#数据库连接信息
spring.datasource.url=jdbc:mysql://localhost:3306/eran?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8
#数据库用户名
spring.datasource.username=root
#数据库密码
spring.datasource.password=root

配置的属性值根据自己的实际情况填写,这里是我的配置,特别要注意实体类的位置以及xml文件的位置。

构建MVC项目结构

创建出对应的包即可,这里我们就创建了几个需要的包就可以了,项目结构如下图:

在这里插入图片描述

数据库sql

CREATE TABLE `sys_user` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `usercode` varchar(32) NOT NULL COMMENT '账号',
  `username` varchar(64) NOT NULL COMMENT '姓名',
  `password` varchar(32) NOT NULL COMMENT '密码',
  `salt` varchar(64) DEFAULT NULL COMMENT '盐',
  `locked` char(1) DEFAULT NULL COMMENT '账号是否锁定,1:锁定,0未锁定',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

INSERT INTO `sys_user` VALUES ('1', 'Promise', 'eran', '123456', null, '0');

SysUser.java

实体类

package com.web.springbootmybatis.entity;

import java.io.Serializable;

import com.fasterxml.jackson.annotation.JsonProperty;
 
public class SysUser implements Serializable{

    private static final long serialVersionUID = 1L;

    //主键 : id   
    private Long id; 
    
    //账号 : usercode     
    private String usercode; 
    
    //姓名 : username     
    private String username; 
    
    //密码 : password     
    private String password; 
    
    //盐 : salt  
    private String salt; 
    
    //账号是否锁定,1:锁定,0未锁定 : locked     
    private String locked; 
    
    //省略getter,setter方法
}

SysUserMapper.java

dao层接口

package com.web.springbootmybatis.dao;

/**
 * SysUserMapper
 */
import java.util.List;
import java.util.Map;

import  com.web.springbootmybatis.entity.SysUser;
 
public interface SysUserMapper{

    public SysUser findById(Long id);
}

SysUserMapper.xml

由于我使用的是xml版,所以需要添加xml文件,这里只是简单写一下,实际开发中,这些文件我们都是利用插件自动生成的,以后的博客会介绍。

<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.web.springbootmybatis.dao.SysUserMapper">
        <resultMap id="sysUser" type="com.web.springbootmybatis.entity.SysUser">
                  <result column="id" property="id" />
                  <result column="usercode" property="usercode" />
                  <result column="username" property="username" />
                  <result column="password" property="password" />
                  <result column="salt" property="salt" />
                  <result column="locked" property="locked" />
        </resultMap>
    <select id="findById" parameterType="java.lang.Long" resultMap="sysUser">
        SELECT 
            id ,            
            usercode,           
            username,           
            password,           
            salt,           
            locked          
        FROM sys_user
        WHERE
            id=#{id}    
    </select>
</mapper>

ISysUserService.java

service接口

package com.web.springbootmybatis.service;
/**
* @author Promise
* @createTime 2018年12月27日 下午11:11:00
* @description 
*/

import com.web.springbootmybatis.entity.SysUser;

public interface ISysUserService {
    SysUser findById(Long id);
}

SysUserServiceImpl.java

service接口实现

package com.web.springbootmybatis.service.impl;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import com.web.springbootmybatis.dao.SysUserMapper;
import com.web.springbootmybatis.entity.SysUser;
import com.web.springbootmybatis.service.ISysUserService;

/**
* @author Promise
* @createTime 2018年12月27日 下午11:11:48
* @description 
*/
@Service("sysUserService")
public class SysUserServiceImpl implements ISysUserService{

    @Autowired
    private SysUserMapper sysUserMapper;
    
    @Override
    public SysUser findById(Long id) {
        // TODO Auto-generated method stub
        return sysUserMapper.findById(id);
    }
}

TestController.java

控制器

package com.web.springbootmybatis.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.web.springbootmybatis.entity.SysUser;
import com.web.springbootmybatis.service.ISysUserService;

/**
* @author Promise
* @createTime 2018年12月27日 下午11:13:22
* @description 
*/
@RestController
public class TestController {

    @Autowired
    private ISysUserService sysUserService;
    
    @RequestMapping("/user")
    public SysUser getUser() {
        return sysUserService.findById(1L);
    }
}

添加注解扫描dao层

在启动类中添加注解@MapperScan()注解配置扫描dao层位置,里边的值根据实际情况填写。

package com.web.springbootmybatis;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
@MapperScan("com.web.springbootmybatis.dao")
public class SpringbootMybatisApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringbootMybatisApplication.class, args);
    }

}

此时项目的结构为:

在这里插入图片描述

启动项目

启动项目,访问localhost:8080/user或者127.0.0.1:8080/user,得到如下信息:

在这里插入图片描述

拿到了数据库中存放的用户信息,至此Spring boot简单整合Mybatis就成功了,这里我们使用的是默认的tomcat-jdbc数据源,在实际开发过程中我们一般使用alibaba提供的功能更强大的druid数据源,后边的博客会详细介绍,这里就不概述了。

打印sql

细心的小伙伴会发现按照上边的配置,我们访问了数据库,但是控制台并没有打印出我们具体的sql语句,这在实际开过程中是非常不友好的,看不到sql语句非常不利于我们快速的定位bug,所以下面介绍以下在Spring boot中开启sql日志的功能,很简单,只需要在配置文件中添加一句配置即可:

logging.level.com.web.springbootmybatis.dao=debug

logging.level后面的路径指的是mybatis对应的方法接口所在的包(也就是dao层所在的包),并不是mapper.xml所在的包。

重启项目,再次访问,观察控制台是不是已经打印出了sql语句了呢:

在这里插入图片描述

结语

关于Spring boot整合Mybatis的介绍就到这里了,下面的博客中会继续介绍Mybatis的自动化插件以及分页插件,使用druid数据源等,bye~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容