SpringBoot+Mybatis开发

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


文章目录

  • SpringBoot+Mybatis开发
  • 前言
  • 一、环境设置
  • 1.依赖引入
  • 2,yml设置
  • 二、层次结构
  • 1. Entity层
  • 2. Controller层
  • 3. Service层
  • 4. Dao层
  • 5. xml数据库操作文件



前言

提示:这里可以添加本文要记录的大概内容:

SpringBoot+MyBatis的后端开发模式目前很受欢饮,本文章搭建一个简单的基于SpringBoot+MyBatis的项目


提示:以下是本篇文章正文内容,下面案例可供参考

一、环境设置

1.依赖引入

现在使用了MAVEN以后,导入依赖包可以说很方便了,在pom里面引入:

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</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>
            <version>5.1.47</version>
        </dependency>

mybatis的依赖最好用上面的依赖,不然老是容易出问题。

2,yml设置

我一直喜欢用yml而不是默认的property,因为yml编写习惯更贴近java思维,风格和json非常接近。数据库连接如下:

server:
  port: 8081
spring:
  datasource:
    username: root
    password: 123456
    url:  jdbc:mysql://localhost:3306/?useSSL=false
    driver-class-name: com.mysql.jdbc.Driver


mybatis:
  type-aliases-package: com.example.demo2.Entity
  mapper-locations: classpath:Mapper/*.xml

其中, type-aliases-package指示了MyBatis对应数据库的实体,本质上,MyBatis是通过xml文件编写数据库操作语句,而 type-aliases-package则指定了该xml中数据库实体对应的java实体。mapper-locations指定了xml文件所在的位置。mapper-locations寻址一般从resource文件为根目录。

![在这里插入图片描述](

springboot和mybatisplus版本对照 springboot和mybatis整合开发文档_java

二、层次结构

1. Entity层

是实体层。可以快捷生成。但是注意,要有主键@Id,可以用IDEA快速生成。一般有两种方式,一是

@Entity
@Table(name = "user", schema = "demo", catalog = "")
@TableName(value = "user")
public class User {
    private int userId;
    private String password;
    private String name;
    private String position;


    @Id
    @Column(name = "userId", nullable = false)
    public int getUserId() {
        return userId;
    }

    public void setUserId(int userId) {
        this.userId = userId;
    }

    @Basic
    @Column(name = "password", nullable = true, length = 255)
    public String getPassword() {
        return password;
    }

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

    @Basic
    @Column(name = "name", nullable = true, length = 255)
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Basic
    @Column(name = "position", nullable = true, length = 255)
    public String getPosition() {
        return position;
    }

    public void setPosition(String position) {
        this.position = position;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        User that = (User) o;
        return userId == that.userId &&
                Objects.equals(password, that.password) &&
                Objects.equals(name, that.name) &&
                Objects.equals(position, that.position);
    }

    @Override
    public int hashCode() {
        return Objects.hash(userId, password, name, position);
    }
}

2. Controller层

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

    @Autowired
    UserService userService; 
    @RequestMapping("query")
    List<User> query (){
        return userService.selectAll();
    } 
}

3. Service层

Service分为接口和实现。注解@Svevice必须放在实现而不是接口中。调用时调用接口。

@Service
public class UserServoceImpl implements UserService {

    @Autowired
    UserDao userDao;
    @Override
    public List<User> selectAll() {
         return userDao.selectAll();
    }
}

4. Dao层

其中@Mapper注解一定不能少!@Mapper是MyBatis提供的而不是Spring提供的,使用后会生成Mapper的实现。接口一般不能注解,@Mapper一般用在接口类上,在编译之后会生成相应的接口实现类(因此在service中注解一般放在实现而不是接口)。此外,还应该加一个@Component注解,以便被其他类依赖注入。

@Mapper
@Component
public interface UserDao {
    public List<User> selectAll();

}

该层是最容易出bug的一层,最逗的问题便是无法找到该层dao的bean,其中原因很多,不止在该文件会引起问题,在pom设置,或者mapper.xml的实现中,一旦路径引用不正确,都会导致无法生成bean对象!

5. xml数据库操作文件

Mybatis把对数据库的操作全部放入到了xml文件中。
文件中的namespace表示绑定数据库文件接口的地方,在接口处使用@Mapper生成接口。具体的数据库操作中的resultType是数据库执行后的返回值类型,其类型种类如果是自定义(如实体),则实体应该在pom文件的type-aliases-package中声明,否则返回结果会出错。

<?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.example.demo2.Dao.UserDao">

    <select id="selectAll" resultType="User">
        select * from user
    </select> 
</mapper>