MyBatis-Plus入门篇——CRUD

MyBatis-Plus入门篇——CRUD_第1张图片

写在前面

有粉丝私信我说,现在市面上用MyBatis的不多了,一般都是用MyBatis-Plus,建议我出一套MyBatis-Plus的文章,首先感谢建议,然后就是干!

MyBatis-Plus简介

MyBatis-Plus(简称MP),其实就是MyBatis的一个增强,即把单表的增删改查给封装好了,直接拿来使用即可。

准备工作
首先创建一张数据库表

DROP TABLE IF EXISTS user;

CREATE TABLE user
(
	id BIGINT(20) NOT NULL COMMENT '主键ID',
	name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',
	age INT(11) NULL DEFAULT NULL COMMENT '年龄',
	email VARCHAR(50) NULL DEFAULT NULL COMMENT '邮箱',
	PRIMARY KEY (id)
);

对应的数据如下

DELETE FROM user;

INSERT INTO user (id, name, age, email) VALUES
(1, 'Jone', 18, '[email protected]'),
(2, 'Jack', 20, '[email protected]'),
(3, 'Tom', 28, '[email protected]'),
(4, 'Sandy', 21, '[email protected]'),
(5, 'Billie', 24, '[email protected]');

创建SpringBoot项目
创建一个普通的SpringBoot项目,然后引入依赖,既然要跟数据库打交道,connector肯定不能少


    mysql
    mysql-connector-java
    8.0.18

另外要使用mybatis-plus,当然也要引入该starter


    com.baomidou
    mybatis-plus-boot-starter
    3.4.1

为了方便起见,这里引入Lombok


    org.projectlombok
    lombok
    true

好了,依赖引入完毕,下面进行简单配置

spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/mybatis_plus?userSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
    username: root
    password: root

配置也写好了,那么可以开始用了。
CRUD
在操作之前需要先创建一个实体类

@Data
public class User {
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

实体类写好之后,编写一个mapper接口,只需继承BaseMapper,基本的单表查询都给你封装好了,真是太贴心了。

@Repository
@Mapper
public interface UserMapper extends BaseMapper {

}

测试

@Test
void myInsert() {
    User user = new User();
    user.setName("贺志营");
    user.setEmail("[email protected]");
    user.setAge(18);
    userMapper.insert(user);
}

@Test
void myDelete() {
    userMapper.deleteById(1);
}

@Test
void myUpdate() {
    User user = new User();
    user.setId(1L);
    user.setName("贺志营");
    user.setEmail("[email protected]");
    user.setAge(18);
    userMapper.updateById(user);
}

@Test
void mySelect() {
    List users = userMapper.selectList(null);
    users.forEach(System.out::println);
}

问题
我们会发现,在进行插入的时候,id是一串很长的数字,好像不是自增的,那么我们需要怎么做才能让他自增呢,两部曲:1、在数据库中修改id字段为自增。2、在实体类id上加上一个注解。

@Data
public class User {
    @TableId(type = IdType.AUTO)
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

然后再次操作就是自增了。
MyBatis-Plus入门篇——CRUD_第2张图片
完事收工。

微信搜一搜【贺贺学编程】关注这个不一样的程序员,关注后回复【面试】获取海量面试题,联系我还有机会获得模拟面试机会。

你可能感兴趣的:(MyBatis,java,mybatis)