学习在idea里面使用springboot和mybatis整合并实现从数据库获取用户信息

一、新建一个spring boot项目

1、首先,新建一个spring boot项目,这里选中  Spring Initializr,然后选择java版本,点击next,如下图所示;

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_spring

  

2、输入包名,其他选择默认,点击next,如下图所示;

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_mybatis_02

  

3、选中web,后,选择spring web,也可以在上方更换spring boot版本,点击next,如下图所示;

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_intellij idea_03

  

4、输入项目名,和项目路径,点击finish,如下图所示;

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_spring boot_04

二、添加mybatis

1、现在一个spring boot项目就建好了,我们开始添加mybatis的maven依赖,打开pom.xml,在dependencies里面的最下面的dependence标记下方新增如下代码

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
            <version>2.2.2.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>5.2.2.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.4</version>
        </dependency>

        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.0.0</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.10</version>
        </dependency>

添加好后,pom文件可能会有报错,因为有的jar包之前没有下载过,点击maven的刷新,就会自动下载没有的jar包,下载完报错就会消失。

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_spring boot_05

三、配置数据源

在application.yml或者aplication.properties中添加数据库连接的主机、用户和密码,我用的是application.yml,代码格式如下

spring:
  datasource:
    url: jdbc:mysql://主机地址:3306/testdb?useUnicode=true&characterEncoding=UTF-8&useSSL=false
    username: adminblog
    password: H18585924921hp
    driver-class-name: com.mysql.cj.jdbc.Driver

四、使用idea的database管理数据库

打开database管理界面,点击加号,选择Database source -> mysql 第一行name谁便填,填写好主机名、用户和密码后,点击test connection 下方有绿色的勾说明连接成功了,点击ok。如下图所示:

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_spring boot_06

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_spring_07

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_spring boot_08

  

五、安装Free mybatis plugin 自动生成mybatis的mapper插件 

依次点击 File -> setting ->plugin 搜索free mybatis plugin插件 ,点击安装。

六、生成mybatis的mapper相关文件

1、先在新建好项目所需的相关包和文件夹,如下图所示:

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_spring boot_09

  

2、在database界面选中目标表,右键点击mybatis-generate ,填好package的位置,点击ok完成实体类、mapper类和mapper的xml 的自动添加,如下图所示:

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_mybatis_10

七、获取数据库的一条数据

1、现在入口函数Demoapplication.java里添加mapper的自动扫描注解

package com.ssmproject.demo;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@MapperScan("com.ssmproject.demo.dao")
@SpringBootApplication
public class DemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }

}

2、在service包里面新建一个adminservice.java接口,添加获取用户方法,代码如下:

package com.ssmproject.demo.service;

import com.ssmproject.demo.entity.Admin;

public interface AdminService {
    public Admin getAdminById(int id);
}

新建一个impl实现接口包,在包里面新增adminserviceimpl类继承自adminservice,并在里面实现获取用户函数;admindao的注入;还需在类上面添加@Service注解,完整代码如下:

package com.ssmproject.demo.service.impl;

import com.ssmproject.demo.dao.AdminDao;
import com.ssmproject.demo.entity.Admin;
import com.ssmproject.demo.service.adminservice;
import org.springframework.stereotype.Service;

import javax.annotation.Resource;

@Service
public class AdminServiceImpl implements AdminService {
    
    @Resource
    private AdminDao adminDao;
    
    @Override
    public Admin getAdminById(int id) {
        Admin admin=adminDao.selectByPrimaryKey(id);
        return admin;
    }
}

3、在controller包新建AdminController,在里面添加一个请求获取一条用户信息,完整代码如下:

package com.ssmproject.demo.controller;

import com.ssmproject.demo.entity.Admin;
import com.ssmproject.demo.service.AdminService;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import javax.annotation.Resource;

@Controller
public class AdminController {

    @Resource
    private AdminService adminService;

    @RequestMapping("/getadmin")
    @ResponseBody
    public Admin getAdmin(){
        Admin admin=adminService.getAdminById(3);
        return admin;
    }

}

4、最后一步,在application.yml中添加,mapper的xml文件的扫描路径,代码如下:

mybatis:
  configuration:
    map-underscore-to-camel-case: true
  mapper-locations: classpath:/mapper/*.xml

此时application.yml的完整代码如下

spring:
  datasource:
    url: jdbc:mysql://主机名:3306/testdb?useUnicode=true&characterEncoding=UTF-8&useSSL=false
    username: adminblog
    password: H18585924921hp
    driver-class-name: com.mysql.cj.jdbc.Driver

mybatis:
  configuration:
    map-underscore-to-camel-case: true
  mapper-locations: classpath:/mapper/*.xml

八、项目完成

启动项目,打开DemoApplication.java,右键run "DemoApplication"。 控制台无报错,浏览器上输入http://localhost:8080/getadmin,成功获取一条用户信息

Spring Boot集成MyBatis查询 springboot集成mybatis步骤_intellij idea_11

九、总结

如果按照上面一步一步来,一般都不会错。如果有问题请在下面评论区留言!!!