MybatisPlus快速使用

MybatisPlus快速使用

1.MybatisPlus简介

MyBatis Plus是一个基于MyBatis的增强工具,旨在简化和增强与数据库交互的开发过程。它提供了一系列的功能和特性,使得使用MyBatis更加便捷和高效。

MyBatis Plus的一些主要特点和功能:

  1. 简化的CRUD操作:MyBatis Plus提供了一组简化的API,使得进行常见的CRUD操作变得更加简单和直观。你可以使用它提供的方法来执行插入、更新、删除和查询操作,而无需编写繁琐的SQL语句。
  2. 自动生成代码:MyBatis Plus可以根据数据库表结构自动生成实体类、Mapper接口和XML映射文件,大大减少了手动编写这些代码的工作量。你只需要定义好表结构,然后使用MyBatis Plus提供的代码生成器即可生成所需的代码。
  3. 分页查询支持:MyBatis Plus提供了强大的分页查询功能,可以轻松地进行分页查询操作。你可以指定页码、每页记录数和排序规则,MyBatis Plus会自动处理分页查询并返回结果。
  4. 条件构造器:MyBatis Plus提供了条件构造器(Wrapper)的功能,可以方便地构建复杂的查询条件。你可以使用条件构造器来拼接各种查询条件,如等于、大于、小于、模糊查询等。
  5. 逻辑删除支持:MyBatis Plus支持逻辑删除,可以通过注解或配置来标识逻辑删除的字段,并自动处理逻辑删除操作。你可以方便地进行逻辑删除和查询未被删除的记录。
  6. 乐观锁支持:MyBatis Plus提供了乐观锁的支持,可以通过注解或配置来标识乐观锁的字段,并自动处理乐观锁的并发控制。
  7. Lambda表达式支持:MyBatis Plus支持使用Lambda表达式来构建查询条件,使得查询代码更加简洁和易读。

2.快速搭建

2.1初始化工程

创建一个空的 Spring Boot 工程

在这里插入图片描述

这里我们直接跳过

在这里插入图片描述

2.2添加依赖

引入 Spring Boot Starter 父工程:

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.5+ 版本</version>
    <relativePath/>
</parent>

引入 spring-boot-starterspring-boot-starter-testmybatis-plus-boot-startermysql lombok依赖:

<dependencies>
    <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.2</version>
        </dependency>
        <dependency>
            <groupId>com.mysql</groupId>
            <artifactId>mysql-connector-j</artifactId>
            <scope>runtime</scope>
        </dependency>
    <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
</dependencies>

2.3配置

在application.yml配置文件中添加mysql数据库的相关配置

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/testdb?serverTimezone=GMT%2B8&useSSL=false
    username: root
    password: 123456

在 Spring Boot 启动类中添加 @MapperScan 注解,扫描 Mapper 文件夹:

@SpringBootApplication
//根据自己的项目路径修改
@MapperScan("com.cqgcxy.mapper")
public class Application {

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

}

2.4编码

编写实体类 User

@Data
@TableName("`user`")//指定数据库的user表
public class User {
    
    @TableId(value = "uid", type = IdType.AUTO)
    private Integer uid;

    @TableField("userName")
    private String username;

    @TableField("userPassword")
    private  String userpassword;

    private Integer sex;

    private String hobbit;

    private String degree;

    private String note;

    private Integer rule;

    private Integer state;

}

编写 Mapper 包下的 UserMapper接口

@Mapper
public interface UserMapper extends BaseMapper<User> {
    
}

手写编码太麻烦可以选择代码生成器,MybatisPlus有详细介绍,或者去 SpringBoot入门配置和代码生成器-CSDN博客

3.开始使用

MybatisPlus提供了很多模板供我们使用,我们在这里对部分模板进行学习, 选择测试类,进行功能测试:

UserMapper 中的 selectList() 方法的参数为 MP 内置的条件封装器 Wrapper,所以不填写就是无任何条件

/**
     * 查询user表全部数据
     */
    @Test
    void selectUserAll() {
        List<User> userList = userMapper.selectList(null);
        userList.forEach(System.out::println);
    }

控制台输出

User(uid=1, username=aa, userpassword=123456, sex=0, hobbit=打游戏, degree=本科, note=张三, rule=0, state=1)
User(uid=2, username=bb, userpassword=123456, sex=1, hobbit=, degree=博士, note=李四, rule=0, state=1)
User(uid=3, username=cc, userpassword=123456, sex=0, hobbit=, degree=硕士, note=王五, rule=1, state=1)
User(uid=4, username=哈哈, userpassword=123456, sex=1, hobbit=rap, degree=本科, note=老六, rule=0, state=1)
User(uid=13, username=小小, userpassword=123456, sex=null, hobbit=null, degree=null, note=null, rule=null, state=null)
User(uid=14, username=大大, userpassword=123456, sex=null, hobbit=null, degree=null, note=null, rule=null, state=null)
User(uid=15, username=大明, userpassword=123456, sex=null, hobbit=null, degree=null, note=null, rule=null, state=null)
User(uid=16, username=小a, userpassword=987654, sex=null, hobbit=null, degree=null, note=null, rule=null, state=null)
  • 35
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值