1. 数据准备
在本地创建数据库 mybatis_plus
CREATE DATABASE `mybatis_plus` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;
数据库中创建表 user
CREATE TABLE `user` (
`id` bigint(20) NOT NULL COMMENT '主键ID',
`name` varchar(30) DEFAULT NULL COMMENT '姓名',
`age` int(11) DEFAULT NULL COMMENT '年龄',
`email` varchar(50) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
user 表中添加数据
INSERT INTO user (id, name, age, email) VALUES
(1, 'Jone', 18, 'test1@baomidou.com'),
(2, 'Jack', 20, 'test2@baomidou.com'),
(3, 'Tom', 28, 'test3@baomidou.com'),
(4, 'Sandy', 21, 'test4@baomidou.com'),
(5, 'Billie', 24, 'test5@baomidou.com');
2.通过 Idea 生成一个 springboot 项目
pom.xml 配置如下
<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>
<!-- mybatis 启动类-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.1</version>
</dependency>
<!-- 通过注解生成 get set 构造函数等方法-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<!-- mysql驱动 这里用的是 springboot 自带的驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!-- 阿里数据库连接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.2.8</version>
</dependency>
</dependencies>
application.yml 配置如下:
spring:
datasource:
# 配置数据源类型
type: com.alibaba.druid.pool.DruidDataSource
# 配置连接数据库信息
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/mybatis_plus?characterEncoding=utf-8&useSSL=false
username: root
password: root
创建实体类 User
import lombok.Data;
@Data //lombok注解 生成get set 构造方法等
public class User {
private Long id;
private String name;
private Integer age;
private String email;
}
创建 UserMapper
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.zym.mybatisplus.domain.User;
import org.springframework.stereotype.Repository;
@Repository
public interface UserMapper extends BaseMapper<User> {
}
主启动类添加 @MapperScan ,详细如下
/**
* @MapperScan 扫描 mapper 包,我的包是com.zym.mybatisplus.mapper,你们改成自己的包哈
*/
@SpringBootApplication
@MapperScan("com.zym.mybatisplus.mapper")
public class MybatisplusApplication {
public static void main(String[] args) {
SpringApplication.run(MybatisplusApplication.class, args);
}
}
3.测试
@SpringBootTest
class MybatisplusApplicationTests {
@Autowired
private UserMapper userMapper;
@Test
public void testSelectList(){
// 查询user表中的所有数据
List<User> users = userMapper.selectList(null);
// 遍历打印 user 表中的数据
for (User user : users) {
System.out.println(user.toString());
}
}
}
结果打印出数据库中的五条数据
4.其它方法测试
4.1 新增方法
@Test
public void testInsert()
{
User user = new User();
user.setAge(30);
user.setName("赵义明");
user.setEmail("824898869@qq.com");
// insert 方法返回的是影响行数
int result = userMapper.insert(user);
System.out.println("影响行数:"+result);
// mybatisplus 帮我们新增数据会不会返回ID呢? 看运行结果,答案是会返回新数据的ID
System.out.println("user对象ID:"+user.getId());
}
结果
4.2 删除方法
@Test
public void testDelete()
{
// 根据ID删除数据
int result1 = userMapper.deleteById(1548946947622506497L);
System.out.println("影响的行数:"+result1);
// 根据条件删除
Map<String,Object> map = new HashMap<String,Object>();
map.put("age",24);
map.put("name","Billie");
int result2 = userMapper.deleteByMap(map);
System.out.println("影响的行数"+result2);
List<Long> longs = Arrays.asList(1L, 2L);
int result3 = userMapper.deleteBatchIds(longs);
System.out.println("影响的行数"+result3);
}
结果
4.3 根据ID修改数据
@Test
public void testUpdate()
{
User user = new User();
user.setId(3L);
user.setName("李四");
int result = userMapper.updateById(user);
System.out.println("受影响的行数:"+result);
}
结果
4.4查询信息
@Test
public void testSelect()
{
// 根据ID查询信息
User user = userMapper.selectById(4L);
System.out.println("根据ID查询信息:"+user);
// 根据ID查询信息
List<Long> ids = Arrays.asList(3L, 4L);
List<User> users = userMapper.selectBatchIds(ids);
for (User user1 : users) {
System.out.println("根据ID批量查询信息:"+ user1);
}
// 根据map条件查询用户信息
Map<String,Object> map = new HashMap<String,Object>();
map.put("name","李四");
map.put("age",28);
List<User> users1 = userMapper.selectByMap(map);
for (User user1 : users1) {
System.out.println("根据map条件查询用户信息:"+user1);
}
}
结果
五、通用service
通用 Service CRUD 封装IService接口,进一步封装 CRUD 采用 get 查询单行 remove 删
除 list 查询集合 page 分页 前缀命名方式区分 Mapper 层避免混淆
MyBatis-Plus中有一个接口 IService和其实现类 ServiceImpl,封装了常见的业务层逻辑,详情查看源码IService和ServiceImpl
新建 UserService接口 集成 IService
package com.zym.mybatisplus.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.zym.mybatisplus.domain.User;
/**
* UserService继承IService模板提供的基础功能
*/
public interface UserService extends IService<User>
{
}
新建 UserServiceImpl
package com.zym.mybatisplus.service.impl;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.zym.mybatisplus.domain.User;
import com.zym.mybatisplus.mapper.UserMapper;
import com.zym.mybatisplus.service.UserService;
import org.springframework.stereotype.Service;
/**
* ServiceImpl实现了IService,提供了IService中基础功能的实现
* 若ServiceImpl无法满足业务需求,则可以使用自定的UserService定义方法,并在实现类中实现
*/
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService
{
}
测试
import com.zym.mybatisplus.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
public class Test01 {
@Autowired
private UserService userService;
@Test
public void getCount(){
long count = userService.count();
System.out.println("总记录数:"+count);
}
}
结果