Spring Boot3.4.1 集成 mybatis plus

Spring Boot 集成 mybatis plus

第一步 引入依赖
xml 复制代码
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.16</version>
</dependency>

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-spring-boot3-starter</artifactId>
    <version>3.5.10.1</version>
</dependency>

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-jsqlparser</artifactId>
    <version>3.5.10.1</version>
</dependency>

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.2.15</version>
</dependency>
第二步 引入配置
yml 复制代码
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    driverClassName: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/boot?useUnicode=true&characterEncoding=utf8&useSSL=true&serverTimezone=Asia/Shanghai
    username: root
    password: 123456
mybatis-plus:
  mapper-locations: classpath:/mapper/*Mapper.xml
  global-config:
    banner: false
    db-config:
      id-type: ASSIGN_ID
  configuration:
    map-underscore-to-camel-case: true
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    call-setters-on-nulls: true
第三步 引入配置类
java 复制代码
@Configuration
@MapperScan("com.demo.Mapper")
public class MybatisPlusConfig {
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        // 配置分页插件
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        // 增加@Version乐观锁支持
        interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
        return interceptor;
    }
}
第四步 代码编写

实体类

java 复制代码
@TableName("t_emp")
public class Emp {
    @TableId(value = "emp_id")
    private int empId; // 注意:在Java中通常使用驼峰命名法,因此emp_id变为empId
    @TableField(value = "emp_name" , exist = true)
    private String empName;
    private Integer age;
    private Character sex;
    private String email;

    // 无参构造函数
    public Emp() {
    }

    // 全部参数的构造函数
    public Emp(int empId, String empName, Integer age, Character sex, String email) {
        this.empId = empId;
        this.empName = empName;
        this.age = age;
        this.sex = sex;
        this.email = email;
    }

    // Getter和Setter方法
    public int getEmpId() {
        return empId;
    }

    public void setEmpId(int empId) {
        this.empId = empId;
    }

    public String getEmpName() {
        return empName;
    }

    public void setEmpName(String empName) {
        this.empName = empName;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public Character getSex() {
        return sex;
    }

    public void setSex(Character sex) {
        this.sex = sex;
    }

    public String getEmail() {
        return email;
    }

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

    @Override
    public String toString() {
        String ret = "Emp{" +
                "empId=" + empId +
                ", empName='" + empName + '\'' +
                ", age=" + age +
                ", sex='" + sex + '\'' +
                ", email='" + email + '\'' +
                '}';
        return ret;
    }
}

编写mapper接口

java 复制代码
@Mapper
public interface EmpMapper extends BaseMapper<Emp> {

    Emp selectEmpById(int empId);
    List<Emp> selectAllEmp(@RequestParam("dto") Emp emp);
    @Select("SELECT * FROM  t_emp WHERE 1=1")
    IPage<Emp> selectEmpPage(IPage<Emp> page);
    @Select("SELECT * FROM  t_emp WHERE 1=1")
    List<Emp> selectEmpList(IPage<Emp> page);

}

编写mapper的sql映射文件

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.demo.mapper.EmpMapper">

    <select id="selectEmpById" resultType="com.demo.entity.Emp">
        select * from t_emp where emp_id = #{empId}
    </select>
    <select id="selectAllEmp" resultType="com.demo.entity.Emp">
        select * from t_emp
    </select>
</mapper>

编写service类

java 复制代码
@Service
public class EmpServiceImpl extends ServiceImpl<EmpMapper, Emp> implements EmpService {

    private static Logger logger = LoggerFactory.getLogger(EmpServiceImpl.class);

    public Emp selectEmpById(int empId) {
        return baseMapper.selectEmpById(empId);
    }

    public List<Emp> selectAllEmp(Emp emp) {
        return baseMapper.selectAllEmp(emp);
    }

    public int insertEmp(Emp emp) {
        return baseMapper.insert(emp);
    }

    public Page<Emp> selectEmpPage(Page<Emp> page) {
        LambdaQueryWrapper <Emp> wrapper = new LambdaQueryWrapper<>();
        return baseMapper.selectPage(page,wrapper);
    }

    @Override
    public void updateEmp(Emp emp) {
        baseMapper.updateById(emp);
    }

    @Override
    public void deleteEmp(int empId) {
        baseMapper.deleteById(empId);
    }
}
java 复制代码
public interface EmpService {

    Emp selectEmpById(int empId);
    List<Emp> selectAllEmp(Emp emp);
    int insertEmp(Emp emp);
    Page<Emp> selectEmpPage(Page<Emp> page);

    void updateEmp(Emp emp);

    void deleteEmp(int empId);
}
第五步 测试
java 复制代码
@RestController
@RequestMapping("test")
public class TestController {

    @Autowired
    private RedisUtils redisUtils;

    @Autowired
    private EmpService empService;

    @RequestMapping("/hello")
    public String hello() {
        redisUtils.set("test1","hello world");
        System.out.println(redisUtils.get("test1"));
        List<Emp> emps = empService.selectAllEmp(null);
        System.out.println(emps);
        return "hello";
    }
}
相关推荐
章豪Mrrey nical5 小时前
前后端分离工作详解Detailed Explanation of Frontend-Backend Separation Work
后端·前端框架·状态模式
派大鑫wink6 小时前
【JAVA学习日志】SpringBoot 参数配置:从基础到实战,解锁灵活配置新姿势
java·spring boot·后端
程序员爱钓鱼7 小时前
Node.js 编程实战:文件读写操作
前端·后端·node.js
xUxIAOrUIII7 小时前
【Spring Boot】控制器Controller方法
java·spring boot·后端
Dolphin_Home7 小时前
从理论到实战:图结构在仓库关联业务中的落地(小白→中级,附完整代码)
java·spring boot·后端·spring cloud·database·广度优先·图搜索算法
zfj3217 小时前
go为什么设计成源码依赖,而不是二进制依赖
开发语言·后端·golang
weixin_462446237 小时前
使用 Go 实现 SSE 流式推送 + 打字机效果(模拟 Coze Chat)
开发语言·后端·golang
JIngJaneIL7 小时前
基于springboot + vue古城景区管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
小信啊啊8 小时前
Go语言切片slice
开发语言·后端·golang
全靠bug跑9 小时前
Spring Cloud OpenFeign 实战三部曲:快速集成 · 连接池优化 · 客户端抽取
java·spring boot·openfeign