SpringBoot整合Mybatis 简单试用

1. 导入依赖

  • 我使用MySQL,需要导入MySQL的驱动依赖
  • 此外要在SpringBoot中使用Mybatis,则需要导入Mybatis启动器
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.2.2</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.33</version>
        </dependency>

需要注意版本对应关系,我是用springboot2.7.14,则需要导入2.2或2.3的Mybatis启动器
在这里插入图片描述

2. 配置文件

在springboot的yaml配置文件中把连接数据库所需的spring.datasource和mybatis.mapper-locations配置好。

  • mapper-locations我设置的是classpath:mapper/*.xml,一般都是在
    resource目录下创建一个mapper文件夹,然后把所有的mapper.xml放进去。因此mapper-locations设置为classpath:mapper/*.xml的意思就是扫描mapper文件夹下的所有xml文件作为mybatis的mapper
  • spring.datasource则就是数据库连接所需的driver、url、username、password
mybatis:
  mapper-locations: classpath:mapper/*.xml
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/mytest
    username: root
    password: root

3. 业务场景

dao层创建一个Mapper接口,注意需要用@Mapper标记

@Mapper
public interface UserMapper {
    User getUserByID(int id);
}

对应的在resource/mapper下创建对应的Mapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.wonder.mapper.UserMapper">
    <select id="getUserByID" parameterType="int" resultType="com.wonder.entity.User">
        select * from users where id=#{id}
    </select>
</mapper>

其中用到的entity

package com.wonder.entity;
public class User {
  private long id;
  private String name;
  private String username;
  private String password;
  private java.sql.Timestamp createtime;
  private long roleid;

  public long getId() {
    return id;
  }

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


  public String getName() {
    return name;
  }

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

  public String getUsername() {
    return username;
  }

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

  public String getPassword() {
    return password;
  }

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

  public java.sql.Timestamp getCreatetime() {
    return createtime;
  }

  public void setCreatetime(java.sql.Timestamp createtime) {
    this.createtime = createtime;
  }

  public long getRoleid() {
    return roleid;
  }

  public void setRoleid(long roleid) {
    this.roleid = roleid;
  }
}

用到的数据库表和其中的数据
在这里插入图片描述

4. Service层和Controller层

public interface UserService {
    User getUserByID(int id);
}
@Service
public class UserServiceImpl implements UserService {
    @Autowired
    UserMapper userMapper;

    @Override
    public User getUserByID(int id) {
        return userMapper.getUserByID(id);
    }
}
@Controller
public class UserController {
    @Autowired
    UserService userService;
    
    @RequestMapping("/getUser")
    @ResponseBody
    public User getUserByID(@RequestParam("id") int id){
        return userService.getUserByID(id);
    }
}

5. 测试效果

启动程序,浏览器中输入http://localhost:8080/getUser?id=2
在这里插入图片描述

6. 额外记录

记录下在IDEA中最好安装MyBatisX插件,能够方便的在IDEA中进行mapper和xml之间的跳转。相当好用。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值