使用Spring Boot与MyBatis集成

上一节我们使用JPA来进行数据库操作,这次我们集成MyBatis来操作数据库。Spring Boot与MyBatis集成有两种方式,一种是基于注解,一种是基于XML配置文件。我个人更喜欢使用XML方式,因为更直观,也更容易维护。喜欢使用注解的同学可以移步至http://www.mybatis.org/mybatis-3/zh/java-api.html��。

引入MyBatis及数据库相关依赖

 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-autoconfigure</artifactId>
        </dependency>

        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.1.1</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>

        <dependency>
            <groupId>com.zaxxer</groupId>
            <artifactId>HikariCP</artifactId>
        </dependency>

数据库配置文件

#HikariDataSource database settings
spring.datasource.type=com.zaxxer.hikari.HikariDataSource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/spring_boot?characterEncoding=utf-8
spring.datasource.username=root
spring.datasource.password=123456

spring.datasource.maximum-pool-size=80
spring.datasource.max-idle=10
spring.datasource.max-active=150
spring.datasource.max-wait=10000
spring.datasource.min-idle=5
spring.datasource.initial-size=5
spring.datasource.validation-query=SELECT 1
spring.datasource.test-on-borrow=false
spring.datasource.test-while-idle=true
spring.datasource.time-between-eviction-runs-millis=18800
spring.datasource.jdbc-interceptors=ConnectionState;SlowQueryReport(threshold=0)

mybatis.mapper-locations=classpath*:com/bluecoffee/mapper/**/*Mapper.xml
mybatis.type-aliases-package=com.bluecoffee.domain.**

创建业务实体类

public class Book {

    private Long bookId;

    private String title;

    private String author;

    private Date createTime;

    public Book(){}

    public Book(Long bookId,String title,String author,Date createTime){
        this.bookId = bookId;
        this.title = title;
        this.author = author;
        this.createTime = createTime;
    }

    public Book(String title,String author,Date createTime){
        this.title = title;
        this.author = author;
        this.createTime = createTime;
    }

    //省略getter/setter方法
}

创建数据库操作接口类

@Mapper
public interface BookDao {

    Book getById(Long bookId);

    void insertBook(Book book);

    void deleteAll();

    void updateByPrimaryKey(Book book);

    List<Book> likeTitle(String title);
}

创建SqlMapper.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.bluecoffee.repository.BookDao">

    <resultMap id="bookMap" type="com.bluecoffee.domain.Book">
        <id property="bookId" column="book_id" />
        <result property="title" column="title" />
        <result property="author" column="author" />
        <result property="createTime" column="create_time" />
    </resultMap>

    <delete id="deleteAll">
        delete from BOOK
    </delete>

    <insert id="insertBook" parameterType="com.bluecoffee.domain.Book">
        INSERT
        INTO BOOK(BOOK_ID,TITLE,AUTHOR,CREATE_TIME)
        VALUES
        (#{bookId},#{title},#{author},#{createTime})
    </insert>

    <select id="getById" resultMap="bookMap" resultType="com.bluecoffee.domain.Book">
        SELECT *
        FROM BOOK
        WHERE  book_id = #{bookId,jdbcType=BIGINT}
    </select>

    <select id="likeTitle" resultMap="bookMap" parameterType="string" resultType="java.util.List">
        SELECT *
        FROM BOOK
        WHERE TITLE LIKE CONCAT('%',#{title},'%')
    </select>

    <update id="updateByPrimaryKey" parameterType="com.bluecoffee.domain.Book" >
        update BOOK
        <set >
            <if test="title != null" >
                title = #{title,jdbcType=VARCHAR},
            </if>
            <if test="author != null" >
                author = #{author,jdbcType=VARCHAR},
            </if>
            <if test="createTime != null" >
                create_time = #{createTime,jdbcType=TIMESTAMP},
            </if>
        </set>
        where book_id = #{bookId,jdbcType=BIGINT}
    </update>

</mapper>

完整的项目目录结构如下所示

工程目录

单元测试用例

    @Test
    public void testBook(){
        try{
            //删除所有书籍
            bookDao.deleteAll();

            //创建10本书
            for(int i=1;i<=10;i++){
                bookDao.insertBook(new Book(Long.parseLong(i + ""), "book" + i, "author" + i, new Date()));
            }

            //根据主键查询
            Book book = bookDao.getById(Long.parseLong("9"));
            Assert.assertEquals("book9",book.getTitle());

            //根据主键更新
            book.setBookId(Long.parseLong("9"));
            book.setTitle("book9_update");
            bookDao.updateByPrimaryKey(book);
            Assert.assertEquals("book9_update",book.getTitle());

            //根据书名模糊查询
            List<Book> books = bookDao.likeTitle("book");
            Assert.assertEquals(10,books.size());

        }catch (Exception ex){
            Assert.fail(ex.getMessage());
        }
    }

数据分页

数据分页有很多种方法,Github上有一个不错的插件,我觉得不错,分享一下,项目地址在Mybatis-PageHelper,下面介绍一下使用方法,详细的文档大家可以自己去Github上看看。

引入PageHelper依赖

        <!-- 分页插件 begin-->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper</artifactId>
            <version>4.2.1</version>
        </dependency>
        <dependency>
            <groupId>com.github.jsqlparser</groupId>
            <artifactId>jsqlparser</artifactId>
            <version>0.9.5</version>
        </dependency>
        <!-- 分页插件 end-->

对PageHelper进行基本的配置,该配置必须在Spring Boot启动后就加载

package com.bluecoffee.configuration;

import com.github.pagehelper.PageHelper;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.Properties;

/**
 * MyBatis通用分页插件配置
 *
 * Created by bluecoffee on 16/12/19.
 */
@Configuration
public class MyBatisConfiguration {

    private static final Logger logger = LoggerFactory.getLogger(MyBatisConfiguration.class);

    @Bean
    public PageHelper pageHelper() {
        logger.info("MyBatis PageHelper Register");
        PageHelper pageHelper = new PageHelper();
        Properties p = new Properties();
        p.setProperty("offsetAsPageNum", "true");
        p.setProperty("rowBoundsWithCount", "true");
        p.setProperty("pageSizeZero", "true");
        p.setProperty("reasonable", "false");
        pageHelper.setProperties(p);
        return pageHelper;
    }
}

对分页进行单元测试

    @Test
    public void testPage(){
        try{
            //删除所有书籍
            bookDao.deleteAll();

            //创建8本书
            for(int i=1;i<=8;i++){
                bookDao.insertBook(new Book(Long.parseLong(i + ""), "book" + i, "author" + i, new Date()));
            }

            //根据书名模糊查询,返回第一页数据,每页最多5条数据
            PageHelper.startPage(1, 5);
            List<Book> books = bookDao.likeTitle("book");
            Assert.assertEquals(5,books.size());

            PageHelper.startPage(2, 5);
            books = bookDao.likeTitle("book");
            Assert.assertEquals(3,books.size());

        }catch (Exception ex){
            Assert.fail(ex.getMessage());
        }
    }

完整代码戳这里: Chapter 4-1-2 - Spring Boot集成MyBatis访问数据库

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

推荐阅读更多精彩内容