SpringBoot 整合 MyBatis

2年前 (2022) 程序员胖胖胖虎阿
290 0 0

作者:大三的土狗

专栏:SpringBoot入门到精通
SpringBoot 整合 MyBatis

快速导航

  • 前言
    • 1、创建模块
    • 2、坐标导入
    • 3、项目目录构建
    • 4、编写代码
    • 5、测试
  • 总结

前言

  文本是基于MVC前后端分离模式的一个SpringBoot整合MyBatis的项目,不过没有用到前端页面,使用了更方便的Apifox请求工具。


1、创建模块

1、创建SpringBoot模块

SpringBoot 整合 MyBatis

2、勾选Mysql Driver,Mybatis Framework

SpringBoot 整合 MyBatis

2、坐标导入

因为刚刚以及勾选了mybatis,mysql,所以他们已经添加到了pom.xml中,下面导入其他坐标。

  • lombok 减少get、set方法的编写
  • druid 数据库连接池
		<!--  数据库连接池 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.2.4</version>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

3、项目目录构建

SpringBoot 整合 MyBatis

4、编写代码

1、定义实体类(与数据库一一对应)

SpringBoot 整合 MyBatis

package com.example.mybatis.pojo;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data					#lombok的注解减少getset方法
@AllArgsConstructor
@NoArgsConstructor
public class User {
    private Integer id;
    private String name;
    private String password;

}

2、mapper

package com.example.mybatis.mapper;


import com.example.mybatis.pojo.User;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.stereotype.Repository;


import java.util.List;

@Mapper  // 告诉springboot这是一个mybatis的mapepr类
@Repository   // 将userdao交由spring容齐管理
public interface UserMapper {

    // 查询所有用户
    public List<User> listUser();

}

3、service接口

package com.example.mybatis.service;


import com.example.mybatis.pojo.User;

import java.util.List;

public interface UserService {

    // 查询所有用户
    public List<User> listUser();

}

4、service接口的实现类serviceimpl

package com.example.mybatis.service.impl;

import com.example.mybatis.mapper.UserMapper;
import com.example.mybatis.pojo.User;
import com.example.mybatis.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;


import java.util.List;

@Service   //  交由spring容齐管理
public class UserServiceImpl implements UserService {
    @Autowired
    private UserMapper userMapper;

    @Override
    public List<User> listUser() {
        return userMapper.listUser();
    }

}

5、Controller

package com.example.mybatis.controller;


import com.example.mybatis.pojo.User;
import com.example.mybatis.service.UserService;
import com.example.mybatis.untils.JSONResult;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;


@RestController
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping("/users")
    public JSONResult test(){

       return JSONResult.ok(userService.listUser());

    }

}

6、工具类JSONResult

package com.example.mybatis.untils;

/**
 * 
 * @Title: JSONResult.java
 * @Description: 自定义响应数据结构
 * 				本类可提供给 H5/ios/安卓/公众号/小程序 使用
 * 				前端接受此类数据(json object)后,可自行根据业务去实现相关功能
 * 				200:表示成功
 * 				500:表示错误,错误信息在msg字段中
 * 				501:bean验证错误,不管多少个错误都以map形式返回
 * 				502:拦截器拦截到用户token出错
 * 				555:异常抛出信息
 * 				556: 用户qq校验异常
 * 			    557: 校验用户是否在CAS登录,用户门票的校验
 * @Copyright: Copyright (c) 2020
 */
public class JSONResult {

    // 响应业务状态
    private Integer status;

    // 响应消息
    private String msg;

    // 响应中的数据
    private Object data;
    
    private String ok;	// 不使用

    public static JSONResult build(Integer status, String msg, Object data) {
        return new JSONResult(status, msg, data);
    }

    public static JSONResult build(Integer status, String msg, Object data, String ok) {
        return new JSONResult(status, msg, data, ok);
    }
    
    public static JSONResult ok(Object data) {
        return new JSONResult(data);
    }

    public static JSONResult ok() {
        return new JSONResult(null);
    }
    
    public static JSONResult errorMsg(String msg) {
        return new JSONResult(500, msg, null);
    }

    public static JSONResult errorUserTicket(String msg) {
        return new JSONResult(557, msg, null);
    }
    
    public static JSONResult errorMap(Object data) {
        return new JSONResult(501, "error", data);
    }
    
    public static JSONResult errorTokenMsg(String msg) {
        return new JSONResult(502, msg, null);
    }
    
    public static JSONResult errorException(String msg) {
        return new JSONResult(555, msg, null);
    }
    
    public static JSONResult errorUserQQ(String msg) {
        return new JSONResult(556, msg, null);
    }

    public JSONResult() {

    }

    public JSONResult(Integer status, String msg, Object data) {
        this.status = status;
        this.msg = msg;
        this.data = data;
    }
    
    public JSONResult(Integer status, String msg, Object data, String ok) {
        this.status = status;
        this.msg = msg;
        this.data = data;
        this.ok = ok;
    }

    public JSONResult(Object data) {
        this.status = 200;
        this.msg = "OK";
        this.data = data;
    }

    public Boolean isOK() {
        return this.status == 200;
    }

    public Integer getStatus() {
        return status;
    }

    public void setStatus(Integer status) {
        this.status = status;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public Object getData() {
        return data;
    }

    public void setData(Object data) {
        this.data = data;
    }

	public String getOk() {
		return ok;
	}

	public void setOk(String ok) {
		this.ok = ok;
	}

}

7、配置文件

server:
  port: 8080

# 数据库数据源
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource        # 数据源类型
    username: root
    password: xmpkj
    url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT
    driver-class-name: com.mysql.cj.jdbc.Driver

mybatis:
  mapper-locations: classpath:/mapper/*.xml   #   xml文件

8、mapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.example.mybatis.mapper.UserMapper">

    <select id="listUser" resultType="com.example.mybatis.pojo.User">
        select *from user
    </select>

</mapper>

5、测试

运行项目,打开Postman或者Apifox访问

localhost:8080/users

成功从数据库查到信息

SpringBoot 整合 MyBatis


总结

SpringBoot+MyBatis使用起来更方便,更舒服。掌握SpingBoot整合MyBatis,要比Spring整合简单的多,少了很多繁琐的配置。

版权声明:程序员胖胖胖虎阿 发表于 2022年9月8日 下午5:40。
转载请注明:SpringBoot 整合 MyBatis | 胖虎的工具箱-编程导航

相关文章

暂无评论

暂无评论...