第一步:Maven里面添加mybatis的引用jar包:

<!--mybatis-->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.1</version>
</dependency>
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.2.3</version>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-tx</artifactId>
</dependency>
第二步:在application.properties文件里面添加如下代碼


#配置mysql數(shù)據(jù)源
spring.datasource.url=jdbc:mysql://your-mysql-url/database-name?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true
spring.datasource.username=username
spring.datasource.password=password
spring.datasource.driverClassName=com.mysql.jdbc.Driver

#security.basic.enabled=false

mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl


## Mybatis 配置
mybatis.type-aliases-package=com.xfind.core.entity.xianyu
mybatis.mapper-locations=classpath:mapper/*.xml
#使全局的映射器啟用或禁用緩存。
mybatis.configuration.cache-enabled=true
#全局啟用或禁用延遲加載。當禁用時,所有關(guān)聯(lián)對象都會即時加載。
mybatis.configuration.lazy-loading-enabled=true
#當啟用時,有延遲加載屬性的對象在被調(diào)用時將會完全加載任意屬性。否則,每種屬性將會按需要加載。
mybatis.configuration.aggressive-lazy-loading=true
#是否允許單條sql 返回多個數(shù)據(jù)集  (取決于驅(qū)動的兼容性) default:true
mybatis.configuration.multiple-result-sets-enabled=true
#是否可以使用列的別名 (取決于驅(qū)動的兼容性) default:true
mybatis.configuration.use-column-label=true
#允許JDBC 生成主鍵。需要驅(qū)動器支持。如果設(shè)為了true,這個設(shè)置將強制使用被生成的主鍵,有一些驅(qū)動器不兼容不過仍然可以執(zhí)行。  default:false
mybatis.configuration.use-generated-keys=true
#指定 MyBatis 如何自動映射 數(shù)據(jù)基表的列 NONE:不隱射u3000PARTIAL:部分  FULL:全部
mybatis.configuration.auto-mapping-behavior=partial
#這是默認的執(zhí)行類型  (SIMPLE: 簡單; REUSE: 執(zhí)行器可能重復(fù)使用prepared statements語句;BATCH: 執(zhí)行器可以重復(fù)執(zhí)行語句和批量更新)
mybatis.configuration.default-executor-type=simple
#使用駝峰命名法轉(zhuǎn)換字段。
mybatis.configuration.map-underscore-to-camel-case=true
#設(shè)置本地緩存范圍 session:就會有數(shù)據(jù)的共享  statement:語句范圍 (這樣就不會有數(shù)據(jù)的共享 ) defalut:session
mybatis.configuration.local-cache-scope=session
#設(shè)置但JDBC類型為空時,某些驅(qū)動程序 要指定值,default:OTHER,插入空值時不需要指定類型
mybatis.configuration.jdbc-type-for-null=null
#如果數(shù)據(jù)為空的字段,則該字段省略不顯示,可以通過添加配置文件,規(guī)定查詢數(shù)據(jù)為空是則返回null。
mybatis.configuration.call-setters-on-nulls=true
第三步:設(shè)置啟動類:


//開啟定時任務(wù)
//@EnableScheduling
@SpringBootApplication
@EnableTransactionManagement//開啟事務(wù)管理
@MapperScan("com.xfind.core.mybatis")//與dao層的@Mapper二選一寫上即可(主要作用是掃包)
public class StartUp {
    public static void main(String[] args) {
        SpringApplication.run(StartUp.class, args);
    }
}

第四步:添加mapper文件和編寫dao代碼以及service和controller代碼,
1、我是在core的modules里面的resources文件夾下新建mapper文件夾,下面保存所有數(shù)據(jù)庫訪問的sql。
2、新建實體類,我是在entity文件夾下創(chuàng)建的
2、在dao層下新建mapper里面的方法
3、在service層新建調(diào)用dao層類的邏輯代碼
4、在controller層新建調(diào)用service層的邏輯代碼

UserMapper.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.xfind.core.mybatis.UserDao">
    <select id="findAllUser" resultType="User">
        SELECT * from users
    </select>
</mapper>
User.java


package com.xfind.core.entity.xianyu;

import com.fasterxml.jackson.annotation.JsonIgnore;

import java.util.Date;

/**
 * Created by zhangwei on 2018/6/1.
 */
public class User {
    private String id;
    private String username;
    private String phone;
    private String email;
    @JsonIgnore
    private String password;
    private String ip;
    private String mac;
    private int type;
    private int delFlag;
    private String memo;
    private Date lastPasswordResetDate;

    private Date lastLoginDate;

    private int iosTest;

    private Date createdDt;

    private Date updatedDt;

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPhone() {
        return phone;
    }

    public void setPhone(String phone) {
        this.phone = phone;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public String getIp() {
        return ip;
    }

    public void setIp(String ip) {
        this.ip = ip;
    }

    public String getMac() {
        return mac;
    }

    public void setMac(String mac) {
        this.mac = mac;
    }

    public int getType() {
        return type;
    }

    public void setType(int type) {
        this.type = type;
    }

    public int getDelFlag() {
        return delFlag;
    }

    public void setDelFlag(int delFlag) {
        this.delFlag = delFlag;
    }

    public String getMemo() {
        return memo;
    }

    public void setMemo(String memo) {
        this.memo = memo;
    }

    public Date getLastPasswordResetDate() {
        return lastPasswordResetDate;
    }

    public void setLastPasswordResetDate(Date lastPasswordResetDate) {
        this.lastPasswordResetDate = lastPasswordResetDate;
    }

    public Date getLastLoginDate() {
        return lastLoginDate;
    }

    public void setLastLoginDate(Date lastLoginDate) {
        this.lastLoginDate = lastLoginDate;
    }

    public int getIosTest() {
        return iosTest;
    }

    public void setIosTest(int iosTest) {
        this.iosTest = iosTest;
    }

    public Date getCreatedDt() {
        return createdDt;
    }

    public void setCreatedDt(Date createdDt) {
        this.createdDt = createdDt;
    }

    public Date getUpdatedDt() {
        return updatedDt;
    }

    public void setUpdatedDt(Date updatedDt) {
        this.updatedDt = updatedDt;
    }
}
UserDao.java


@Repository
public interface UserDao {
    List<User> findAllUser();
}
UserService.java


public interface XyUserService {
    List<User> selectUsers();
}
UserServiceImpl.java


@Service
public class XyUserServiceImpl implements XyUserService {

    @Autowired
    UserDao userDao;

    @Override
    public List<User> selectUsers() {
        return userDao.findAllUser();
    }
}
UserController.java

@RestController
@RequestMapping("/xianyu")
public class UserController {

    @Autowired
    XyUserServiceImpl xyUserService;

    @GetMapping("/user")
    public ResponseEntity<?> getUsers(){
        List<User> users = xyUserService.selectUsers();
        return ResponseEntity.ok(users);
    }
}
截圖

第五步:訪問試試是否已經(jīng)設(shè)置成功并返回數(shù)據(jù)

截圖