1. 什么是Mybatis?

MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

2. Spring Boot 整合 Mybatis

  • 2.1 引入maven坐标

    <!--springboot父工程-->
    <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.2.2.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
    </parent> <dependencies>
    <!--springboot框架web组件-->
    <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <version>2.2.2.RELEASE</version>
    </dependency>
    <!--mybatis整合springboot组件-->
    <dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.0</version>
    </dependency>
    <!--mysql数据库连接驱动-->
    <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.18</version>
    </dependency>
    <!--lombok组件-->
    <dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.10</version>
    </dependency>
    </dependencies> <build>
    <!--springboot的maven插件-->
    <plugins>
    <plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
    </plugin>
    <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <configuration>
    <compilerArgs>
    <arg>-parameters</arg>
    </compilerArgs>
    </configuration>
    </plugin>
    </plugins>
    </build>
  • 2.2 编写代码

    • 2.2.1 创建如图所示的目录结构

      记得两个mapper文件的路径要一致,在编译之后mybatis的映射文件和接口文件才会在同一个目录下。

    • 2.2.2 代码编写

      • 2.2.2.1 创建配置文件和启动类

        application.yml

        butterflytri:
        databaseurl-port: 127.0.0.1:3306 # 数据库端口
        database-name: student_db # 数据库名
        server:
        port: 8080 # 应用端口
        servlet:
        context-path: /butterflytri # 应用映射
        spring:
        application:
        name: mybatis # 应用名称
        datasource:
        url: jdbc:mysql://${butterflytri.databaseurl-port}/${butterflytri.database-name}?useUnicode=true&characterEncoding=UTF-8&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
        driver-class-name: com.mysql.jdbc.Driver
        username: root
        password: root
        mybatis:
        type-aliases-package: org.wjf.entity # entity别名
        mapper-locations: classpath:org/wjf/mapper/*Mapper.xml # mapper映射包扫描

        启动类MybatisApplication.java

        package org.butterflytri;
        
        import org.springframework.boot.SpringApplication;
        import org.springframework.boot.autoconfigure.SpringBootApplication; /**
        * @author: WJF
        * @date: 2020/5/16
        * @description: MybatisApplication
        */
        @SpringBootApplication
        public class MybatisApplication { public static void main(String[] args) {
        SpringApplication.run(MybatisApplication.class,args);
        } }
      • 2.2.2.2 创建实体类Student

        在entity包下创建Student.java实体类。

        package org.butterflytri.entity;
        
        import lombok.Getter;
        import lombok.Setter;
        import lombok.ToString; import java.io.Serializable; /**
        * @author: WJF
        * @date: 2020/5/16
        * @description: Student
        */ @ToString
        @Getter
        @Setter
        public class Student implements Serializable { private Long id; private String studentName; private String studentNo; private String sex; private Integer age; }
      • 2.2.2.3 编写mybatis接口文件

        在mapper包下创建StudentMapper.java接口。

        package org.butterflytri.mapper;
        
        import org.apache.ibatis.annotations.Mapper;
        import org.butterflytri.entity.Student; import java.util.List; /**
        * @author: WJF
        * @date: 2020/5/16
        * @description:
        */
        @Mapper
        public interface StudentMapper { /**
        * 查询所有学生信息
        * @return List<Student>
        */
        List<Student> findAll(); /**
        * 通过id查询学生信息
        * @param id
        * @return Student
        */
        Student findOne(Long id); /**
        * 通过学号查询学生信息
        * @param studentNo
        * @return Student
        */
        Student findByStudentNo(String studentNo); }
      • 2.2.2.4 创建mybatis映射文件

        在mapper包下创建StudentMapper.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="org.butterflytri.mapper.StudentMapper">
        <sql id="propertyMapper">
        `ID` AS id,
        `STUDENT_NAME` AS studentName,
        `STUDENT_NO` AS studentNo,
        `SEX` AS sex,
        `AGE` AS age
        </sql>
        <select id="findAll" resultType="org.butterflytri.entity.Student">
        SELECT
        <include refid="propertyMapper"></include>
        FROM
        `t_student`
        </select>
        <select id="findOne" parameterType="java.lang.Long" resultType="org.butterflytri.entity.Student">
        SELECT
        <include refid="propertyMapper"></include>
        FROM
        `t_student`
        WHERE
        `ID` = #{id}
        </select>
        <select id="findByStudentNo" parameterType="java.lang.String" resultType="org.butterflytri.entity.Student">
        SELECT
        <include refid="propertyMapper"></include>
        FROM
        `t_student`
        WHERE
        `STUDENT_NO` = #{studentNo}
        </select>
        </mapper>
      • 2.2.2.5 Service层

        在service包下创建StudentService.java接口,在impl包下创建StudentServiceImpl.Java类并继承StudentService.Java接口。

        StudentService.java

        package org.butterflytri.service;
        
        import org.butterflytri.entity.Student;
        
        import java.util.List;
        
        /**
        * @author: WJF
        * @date: 2020/5/16
        * @description: StudentService
        */ public interface StudentService { public List<Student> findAll(); public Student findOne(Long id); public Student findByStudentNo(String studentNo);
        }

        StudentServiceImpl.java

        package org.butterflytri.service.impl;
        
        import org.butterflytri.entity.Student;
        import org.butterflytri.mapper.StudentMapper;
        import org.butterflytri.service.StudentService;
        import org.springframework.stereotype.Service; import javax.annotation.Resource;
        import java.util.List; /**
        * @author: WJF
        * @date: 2020/5/16
        * @description: StudentServiceImpl
        */
        @Service
        public class StudentServiceImpl implements StudentService { @Resource
        private StudentMapper studentMapper; @Override
        public List<Student> findAll() {
        return studentMapper.findAll();
        } @Override
        public Student findOne(Long id) {
        return studentMapper.findOne(id);
        } @Override
        public Student findByStudentNo(String studentNo) {
        return studentMapper.findByStudentNo(studentNo);
        }
        }
      • 2.2.2.6 Controller层

        在controller包下创建StudentController.java控制器类。

        package org.butterflytri.controller;
        
        import org.butterflytri.entity.Student;
        import org.butterflytri.service.StudentService;
        import org.springframework.web.bind.annotation.RequestMapping;
        import org.springframework.web.bind.annotation.RestController; import javax.annotation.Resource;
        import java.util.List; /**
        * @author: WJF
        * @date: 2020/5/16
        * @description: StudentController
        */
        @RestController
        @RequestMapping("/student")
        public class StudentController { @Resource
        private StudentService studentService; @RequestMapping("/findAll")
        public List<Student> findAll() {
        return studentService.findAll();
        } @RequestMapping("/findOne")
        public Student findOne(Long id) {
        return studentService.findOne(id);
        } @RequestMapping("/findByStudentNo")
        public Student findByStudentNo(String studentNo) {
        return studentService.findByStudentNo(studentNo);
        } }
      • 2.2.2.7 启动工程,访问路径

        启动工程,访问三个接口:

        findAll

        findOne

        findByStudentNo

3. 项目地址

本项目传送门:spring-boot-mybatis

此教程会一直更新下去,觉得博主写的可以的话,关注一下,也可以更方便下次来学习。

Spring Boot 教程(2) - Mybatis的更多相关文章

  1. Spring boot教程mybatis访问MySQL的尝试

    Windows 10家庭中文版,Eclipse,Java 1.8,spring boot 2.1.0,mybatis-spring-boot-starter 1.3.2,com.github.page ...

  2. Spring Boot教程(三十八)使用MyBatis注解配置详解(1)

    之前在Spring Boot中整合MyBatis时,采用了注解的配置方式,相信很多人还是比较喜欢这种优雅的方式的,也收到不少读者朋友的反馈和问题,主要集中于针对各种场景下注解如何使用,下面就对几种常见 ...

  3. Spring Boot教程(三十七)整合MyBatis

    Spring中整合MyBatis就不多说了,最近大量使用Spring Boot,因此整理一下Spring Boot中整合MyBatis的步骤.搜了一下Spring Boot整合MyBatis的文章,方 ...

  4. Spring Boot:整合MyBatis框架

    综合概述 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以使用简单 ...

  5. Spring Boot:实现MyBatis分页

    综合概述 想必大家都有过这样的体验,在使用Mybatis时,最头痛的就是写分页了,需要先写一个查询count的select语句,然后再写一个真正分页查询的语句,当查询条件多了之后,会发现真的不想花双倍 ...

  6. Spring Boot:实现MyBatis动态数据源

    综合概述 在很多具体应用场景中,我们需要用到动态数据源的情况,比如多租户的场景,系统登录时需要根据用户信息切换到用户对应的数据库.又比如业务A要访问A数据库,业务B要访问B数据库等,都可以使用动态数据 ...

  7. Spring Boot:实现MyBatis动态创建表

    综合概述 在有些应用场景中,我们会有需要动态创建和操作表的需求.比如因为单表数据存储量太大而采取分表存储的情况,又或者是按日期生成日志表存储系统日志等等.这个时候就需要我们动态的生成和操作数据库表了. ...

  8. Spring Boot 教程

    Spring Boot 系列教程: Spring Boot:快速入门教程 Spring Boot:整合Swagger文档 Spring Boot:整合MyBatis框架 Spring Boot:实现M ...

  9. 程序员DD 《Spring boot教程系列》补充

    最近在跟着程序员DD的Spring boot教程系列学习Spring boot,由于年代原因,Spring boot已经发生了一些变化,所以在这里进行一些补充. 补充的知识大多来自评论区,百度,Sta ...

随机推荐

  1. 【Linux网络基础】TCP/IP协议簇的详细介绍(三次握手四次断开,11种状态)

    一.TCP/IP协议簇(DoD参考模型) 用于简化OSI层次,以及相关的标准. 传输控制协议(tcp/ip)簇是相关国防部DoD所创建的,主要用来确保数据的完整性以及在毁灭性战争中维持通信 是由一组不 ...

  2. Java算法之 二分搜寻法 ( 搜寻原则的代表)

    为什么80%的码农都做不了架构师?>>>   二分搜寻法 ( 搜寻原则的代表) 1.二分查找又称折半查找,它是一种效率较高的查找方法. 2.二分查找要求:(1)必须采用顺序存储结构 ...

  3. Docker安装和基本操作

    一.Docker安装 CentOS7安装Docker CE $sudo yum install -y yum-utils device-mapper-persistent-data lvm2 $sud ...

  4. CS Requirements and Resources

    有感于国内令人发指的CS教育,决定以自学为主. 路线会按照计算机科学与技术的技能树,主要学习四大的比较完整的课程,video没时间看,但reading会仔细看.lab会认真做,对于一些比较有意义.代码 ...

  5. P1468 派对灯 Party Lamps(BIG 模拟)

    题目描述 在IOI98的节日宴会上,我们有N(10<=N<=100)盏彩色灯,他们分别从1到N被标上号码. 这些灯都连接到四个按钮: 按钮1:当按下此按钮,将改变所有的灯:本来亮着的灯就熄 ...

  6. 题目分享R

    题意:有n只蚂蚁在木棍上爬行,每只蚂蚁的速度都是每秒1单位长度,现在给你所有蚂蚁初始的位置(蚂蚁运动方向未定),蚂蚁相遇会掉头反向运动,让你求出所有蚂蚁都·掉下木棍的最短时间和最长时间. 分析:(其实 ...

  7. 学习笔记之MySQL的使用

    什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库. 每个数据库都有一个或多个不同的 API 用于创建,访问,管理,搜索和复制所保存的数据. 我们也可以将数据存储在文 ...

  8. 前端——Vue.js学习总结一

    一.什么是Vue.js 1.Vue.js 是目前最火的一个前端框架,React是最流行的一个前端框架 2.Vue.js 是前端的主流框架之一,和Angular.js.React.js 一起,并成为前端 ...

  9. 数据结构之递归Demo(走迷宫)(八皇后)(汉诺塔)

    递归 顾名思义,递归就是递归就是递归就是递归就是递归......就是递归 Google递归:

  10. 【Spark】SparkStreaming和Kafka的整合

    文章目录 Streaming和Kafka整合 概述 使用0.8版本下Receiver DStream接收数据进行消费 步骤 一.启动Kafka集群 二.创建maven工程,导入jar包 三.创建一个k ...