Spring boot學(xué)習(xí)(三) Spring boot整合mybatis

前言

前面我們介紹了如何創(chuàng)建一個Spring boot項(xiàng)目以及Spring boot項(xiàng)目的一些基本配置衡蚂,在了解了這些知識的前提下本篇博客繼續(xù)介紹在Spring boot中配置一個基于java的持久層框架---Mybatis

文章首發(fā)于個人博客:【http://www.xiongfrblog.cn

為什么使用Mybatis

在實(shí)際的開發(fā)過程中是離不開數(shù)據(jù)庫的歌焦,這里指的是關(guān)系型數(shù)據(jù)庫榕吼,例如MySql轧邪,Oracle,SqlServer等拖吼。大家應(yīng)該都清楚如果不使用任何框架的情況下鼻疮,我們項(xiàng)目要想連接數(shù)據(jù)庫大致分為以下步驟:

  1. 加載驅(qū)動(使用不同的數(shù)據(jù)庫加載不同的驅(qū)動)
  2. 獲取連接
  3. 編寫sql
  4. 創(chuàng)建statement
  5. 執(zhí)行sql語句并處理結(jié)果
  6. 從下而上依次關(guān)閉連接

實(shí)際的開發(fā)過程中,我們對數(shù)據(jù)庫的操作是很頻繁的借嗽,如果都按照上邊的方式去連接數(shù)據(jù)庫的話态鳖,將會給我們帶來很糟糕的體驗(yàn),所以Mybatis應(yīng)運(yùn)而生淹魄,Mybatis內(nèi)部封裝了jdbc郁惜,使我們開發(fā)者只需要考慮sql語句的編寫堡距,其余的都幫我們搞定甲锡,極大的減輕了開發(fā)人員的工作量,而且還提供了動態(tài)sql等強(qiáng)大功能羽戒,能應(yīng)對實(shí)際項(xiàng)目中的各種需求缤沦,這也是它受到大家青睞的原因。

在Spring boot中配置Mybatis

添加依賴

在整合Mybatis之前先準(zhǔn)備一個干凈的Spring boot項(xiàng)目,然后在pom.xml文件中添加mybatis-spring-boot-starter依賴易稠,因?yàn)樾枰P(guān)聯(lián)到數(shù)據(jù)庫缸废,所以還必須添加一個數(shù)據(jù)庫的依賴,這里我使用的是Mysql數(shù)據(jù)庫驶社,所以需要在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版本對應(yīng)的Mybatis也不一樣企量,詳細(xì)情況可查閱官方文檔【傳送門】。

看到網(wǎng)上很多教程都添加了jdbc的依賴亡电,其實(shí)這里是不需要的届巩,因?yàn)?code>mybatis-spring-boot-starter已經(jīng)包含了spring-boot-starter-jdbc依賴,查看項(xiàng)目中隱形依賴的方法為(使用eclipse):右鍵項(xiàng)目-->Run As-->Maven build...在彈出框的Goals欄中輸入dependency:tree,點(diǎn)擊Run份乒,在控制臺就會打印出項(xiàng)目的所有依賴及關(guān)系恕汇,如圖:

在這里插入圖片描述

圖示內(nèi)容可以證明我上面的言論。

配置數(shù)據(jù)源

application.properties配置文件中添加如下內(nèi)容:

#mybatis配置
#配置實(shí)體類的位置
mybatis.type-aliases-package=com.web.springbootmybatis.entity
#xml文件位置
mybatis.mapper-locations=classpath:mapper/*.xml
#mysql數(shù)據(jù)庫連接信息配置
#mysql驅(qū)動
spring.datasource.driverClassName=com.mysql.jdbc.Driver
#數(shù)據(jù)庫連接信息
spring.datasource.url=jdbc:mysql://localhost:3306/eran?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8
#數(shù)據(jù)庫用戶名
spring.datasource.username=root
#數(shù)據(jù)庫密碼
spring.datasource.password=root

配置的屬性值根據(jù)自己的實(shí)際情況填寫或辖,這里是我的配置瘾英,特別要注意實(shí)體類的位置以及xml文件的位置。

構(gòu)建MVC項(xiàng)目結(jié)構(gòu)

創(chuàng)建出對應(yīng)的包即可颂暇,這里我們就創(chuàng)建了幾個需要的包就可以了缺谴,項(xiàng)目結(jié)構(gòu)如下圖:

在這里插入圖片描述

數(shù)據(jù)庫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

實(shí)體類

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文件煌集,這里只是簡單寫一下妓肢,實(shí)際開發(fā)中,這些文件我們都是利用插件自動生成的苫纤,以后的博客會介紹碉钠。

<?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接口實(shí)現(xiàn)

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層位置,里邊的值根據(jù)實(shí)際情況填寫。

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);
    }

}

此時項(xiàng)目的結(jié)構(gòu)為:

在這里插入圖片描述

啟動項(xiàng)目

啟動項(xiàng)目卷拘,訪問localhost:8080/user或者127.0.0.1:8080/user喊废,得到如下信息:

在這里插入圖片描述

拿到了數(shù)據(jù)庫中存放的用戶信息,至此Spring boot簡單整合Mybatis就成功了栗弟,這里我們使用的是默認(rèn)的tomcat-jdbc數(shù)據(jù)源污筷,在實(shí)際開發(fā)過程中我們一般使用alibaba提供的功能更強(qiáng)大的druid數(shù)據(jù)源,后邊的博客會詳細(xì)介紹乍赫,這里就不概述了瓣蛀。

打印sql

細(xì)心的小伙伴會發(fā)現(xiàn)按照上邊的配置,我們訪問了數(shù)據(jù)庫雷厂,但是控制臺并沒有打印出我們具體的sql語句惋增,這在實(shí)際開過程中是非常不友好的,看不到sql語句非常不利于我們快速的定位bug,所以下面介紹以下在Spring boot中開啟sql日志的功能改鲫,很簡單诈皿,只需要在配置文件中添加一句配置即可:

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

logging.level后面的路徑指的是mybatis對應(yīng)的方法接口所在的包(也就是dao層所在的包),并不是mapper.xml所在的包像棘。

重啟項(xiàng)目稽亏,再次訪問,觀察控制臺是不是已經(jīng)打印出了sql語句了呢:

在這里插入圖片描述

結(jié)語

關(guān)于Spring boot整合Mybatis的介紹就到這里了缕题,下面的博客中會繼續(xù)介紹Mybatis的自動化插件以及分頁插件截歉,使用druid數(shù)據(jù)源等,bye~

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市避除,隨后出現(xiàn)的幾起案子怎披,更是在濱河造成了極大的恐慌,老刑警劉巖瓶摆,帶你破解...
    沈念sama閱讀 217,657評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件凉逛,死亡現(xiàn)場離奇詭異,居然都是意外死亡群井,警方通過查閱死者的電腦和手機(jī)状飞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人诬辈,你說我怎么就攤上這事酵使。” “怎么了焙糟?”我有些...
    開封第一講書人閱讀 164,057評論 0 354
  • 文/不壞的土叔 我叫張陵口渔,是天一觀的道長。 經(jīng)常有香客問我穿撮,道長缺脉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,509評論 1 293
  • 正文 為了忘掉前任悦穿,我火速辦了婚禮攻礼,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘栗柒。我一直安慰自己礁扮,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評論 6 392
  • 文/花漫 我一把揭開白布瞬沦。 她就那樣靜靜地躺著太伊,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蛙埂。 梳的紋絲不亂的頭發(fā)上倦畅,一...
    開封第一講書人閱讀 51,443評論 1 302
  • 那天遮糖,我揣著相機(jī)與錄音绣的,去河邊找鬼。 笑死欲账,一個胖子當(dāng)著我的面吹牛屡江,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播赛不,決...
    沈念sama閱讀 40,251評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼惩嘉,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了踢故?” 一聲冷哼從身側(cè)響起文黎,我...
    開封第一講書人閱讀 39,129評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎殿较,沒想到半個月后耸峭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,561評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡淋纲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評論 3 335
  • 正文 我和宋清朗相戀三年劳闹,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,902評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡本涕,死狀恐怖业汰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情菩颖,我是刑警寧澤样漆,帶...
    沈念sama閱讀 35,621評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站晦闰,受9級特大地震影響氛濒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鹅髓,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評論 3 328
  • 文/蒙蒙 一舞竿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧窿冯,春花似錦骗奖、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至芜赌,卻和暖如春仰挣,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背缠沈。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評論 1 269
  • 我被黑心中介騙來泰國打工膘壶, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人洲愤。 一個月前我還...
    沈念sama閱讀 48,025評論 2 370
  • 正文 我出身青樓颓芭,卻偏偏與公主長得像,于是被迫代替她去往敵國和親柬赐。 傳聞我的和親對象是個殘疾皇子亡问,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評論 2 354

推薦閱讀更多精彩內(nèi)容