写在前面
有粉丝私信我说,现在市面上用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;
}
微信搜一搜【贺贺学编程】关注这个不一样的程序员,关注后回复【面试】获取海量面试题,联系我还有机会获得模拟面试机会。