Mybatis Plus#
约 178 个字 41 行代码 预计阅读时间 4 分钟
入门案例#
创建项目,导入相关依赖:
XML
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>3.3.2</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.luguosong</groupId>
<artifactId>mybatis-plus-hello</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>mybatis-plus-hello</name>
<description>mybatis-plus-hello</description>
<url/>
<licenses>
<license/>
</licenses>
<developers>
<developer/>
</developers>
<scm>
<connection/>
<developerConnection/>
<tag/>
<url/>
</scm>
<properties>
<java.version>17</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--MyBatis-Plus依赖-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-spring-boot3-starter</artifactId>
<version>3.5.7</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
application.yml文件配置数据库连接:
YAML
spring:
datasource:
driverClassName: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/programming_notes
username: root
password: 12345678
sql:
init:
schema-locations: classpath:db/schema.sql
data-locations: classpath:db/data.sql
mode: always
在 Spring Boot 启动类中添加 @MapperScan 注解,扫描 Mapper 文件夹:
Java
package com.luguosong.mybatisplushello;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@MapperScan("com.luguosong.mybatisplushello.mapper")
public class MybatisPlusHelloApplication {
public static void main(String[] args) {
SpringApplication.run(MybatisPlusHelloApplication.class, args);
}
}
编写实体类:
Java
package com.luguosong.mybatisplushello.entity;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
/**
* @author luguosong
*/
@Data
@TableName("`user`")
public class User {
private Long id;
private String name;
private Integer age;
private String email;
}
编写 Mapper 接口类:
Java
package com.luguosong.mybatisplushello.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.luguosong.mybatisplushello.entity.User;
/**
* @author luguosong
*/
public interface UserMapper extends BaseMapper<User> {
}
编写测试类:
Java
package com.luguosong.mybatisplushello;
import com.luguosong.mybatisplushello.entity.User;
import com.luguosong.mybatisplushello.mapper.UserMapper;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.List;
@SpringBootTest
class MybatisPlusHelloApplicationTests {
@Autowired
private UserMapper userMapper;
@Test
void testSelect() {
List<User> users = userMapper.selectList(null);
users.forEach(System.out::println);
}
}
常见注解#
@TableName#
默认情况实体类类名驼峰转下划线作为表名,@TableName
用来自定义表名。
@TableId#
默认情况下实体类名为id的字段作为主键,@TableId
用来自定义主键。
Java
public class User {
@TableId(value = "id", type = IdType.AUTO)
private Long id;
private String name;
}
@TableField#
默认情况下实体类成员字段名驼峰转下划线作为表的字段名,@TableField
用来自定义字段名。
Java
@TableName("tb_user")
public class User {
private Long id;
// 实体类字段名与表字段不一致,可以使用@TableField注解指定表字段名
@TableField("user_name")
private String name;
//当表字段名与mysql关键字冲突,可以使用转义字符处理
@TableField("`order`")
private String order;
// 当实体类字段在表中不存在时
@TableField(exist = false)
private String address;
}
条件构造器#
详细条件构造器参考官网
WrapperTest.java
package com.luguosong.mybatisplushello;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
import com.luguosong.mybatisplushello.entity.User;
import com.luguosong.mybatisplushello.mapper.UserMapper;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.List;
/**
* @author luguosong
*/
@SpringBootTest
public class WrapperTest {
@Autowired
private UserMapper userMapper;
/*
* 条件查询
* */
@Test
void testSelect() {
/*
* 构造条件
* */
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.select("name", "age"); //查询指定字段
wrapper.like("name", "o");
wrapper.ge("age", 20);
/*
* 查询
* */
List<User> users = userMapper.selectList(wrapper);
users.forEach(System.out::println);
}
/*
* 条件更新
* */
@Test
void testUpdate() {
//构造更新条件
UpdateWrapper<User> wrapper = new UpdateWrapper<>();
wrapper.setSql("age=10");
wrapper.in("id", List.of(1, 2, 3));
//更新数据
userMapper.update(null, wrapper);
}
/*
* 使用Lambda构造条件
* 👍🏻推荐使用,防止硬编码
* */
@Test
void testLambdaSelect() {
/*
* 构造条件
* */
LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
wrapper.select(User::getName, User::getAge); //查询指定字段
wrapper.like(User::getName, "o");
wrapper.ge(User::getAge, 20);
/*
* 查询
* */
List<User> users = userMapper.selectList(wrapper);
users.forEach(System.out::println);
}
}