# 增删改查
提示
本章节主要讲解运用MP通用增删改查。案例以springboot融合mybatis-plus的搭建结构为基础,请按照教程操作 或者参考源码 (opens new window)@123
# 增
这里就提供了一个默认方法 参考 官方文档 (opens new window)

@SpringBootTest
public class InsertTest {
@Autowired
private UserMapper userMapper;
@Test
public void insert() {
User user = new User();
user.setAge(12);
user.setId(6L);
user.setName("tom");
user.setEmail("123@qq.com");
int insert = userMapper.insert(user);
System.out.println(insert);
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# 删
有四个方法参考 官方文档 (opens new window)
@SpringBootTest
public class DeleteTest {
@Autowired
private UserMapper userMapper;
/**
* 根据 entity 条件,删除记录
*/
@Test
public void deleteByEntity() {
// 创建一个 Wrapper 条件
QueryWrapper<User> wrapper = Wrappers.query();
// 设置删除条件,例如:id 等于6 的记录
wrapper.eq("id", 6L);
userMapper.delete(wrapper);
}
/**
* 删除(根据ID 批量删除)
*/
@Test
public void deleteBatchIds() {
userMapper.deleteBatchIds(Arrays.asList(1L, 2L));
}
/**
* 根据 ID 删除
*/
@Test
public void deleteById() {
userMapper.deleteById(3L);
}
/**
* 根据 columnMap 条件,删除记录
*/
@Test
public void deleteByMap() {
Map<String, Object> map = new HashMap<>();
map.put("name", "Sandy");
userMapper.deleteByMap(map);
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# 改
一共2个方法参考 官方文档 (opens new window)
@SpringBootTest
public class UpdateTest {
@Autowired
private UserMapper userMapper;
/**
* 根据 ID 修改
*/
@Test
public void updateById() {
User user = new User();
user.setAge(12);
user.setId(6L);
user.setName("tom");
user.setEmail("123@qq.com");
int insert = userMapper.updateById(user);
}
/**
* 根据 whereWrapper 条件,更新记录
*/
@Test
public void update() {
User user = new User();
user.setAge(12);
user.setId(6L);
user.setName("tom");
user.setEmail("123@qq.com");
int insert = userMapper.insert(user);
System.out.println(insert);
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# 查
一共10个方法 方法详情,参考官方文档 (opens new window)
@SpringBootTest
public class SelectTest {
@Autowired
private UserMapper userMapper;
/**
* 根据 ID 查询
*/
@Test
public void selectById() {
User user = userMapper.selectById(1L);
System.out.println(user);
}
/**
* 根据 entity 条件,查询一条记录
*/
@Test
public void selectOne() {
QueryWrapper<User> wrapper = Wrappers.query();
wrapper.eq("id", 2L);
User user = userMapper.selectOne(wrapper);
System.out.println(user);
}
/**
* 查询(根据ID 批量查询)
*/
@Test
public void selectBatchIds() {
List<User> users = userMapper.selectBatchIds(Arrays.asList(1L, 2L));
users.forEach(System.out::println);
}
/**
* 根据 entity 条件,查询全部记录
*/
@Test
public void selectList() {
QueryWrapper<User> wrapper = Wrappers.query();
wrapper.gt("age", 18);
List<User> users = userMapper.selectList(wrapper);
users.forEach(System.out::println);
}
/**
* 查询(根据 columnMap 条件)
*/
@Test
public void selectByMap() {
Map<String, Object> map = new HashMap<>();
map.put("id", 1l);
List<User> users = userMapper.selectByMap(map);
users.forEach(System.out::println);
}
/**
* 根据 Wrapper 条件,查询全部记录
* selectList 和这个功能类似,但是selectList返回的是对象集合
* selectMaps返回的是将属性组织成map的key进行返回,需要根据需求进行选择
*/
@Test
public void selectMaps() {
QueryWrapper<User> wrapper = Wrappers.query();
wrapper.eq("id", 2L);
List<Map<String, Object>> maps = userMapper.selectMaps(wrapper);
maps.forEach(System.out::println);
}
/**
* 根据 Wrapper 条件,查询全部记录。注意: 只返回第一个字段的值
*/
@Test
public void selectObjs() {
QueryWrapper<User> wrapper = Wrappers.query();
wrapper.eq("id", 2L);
List<Object> objs = userMapper.selectObjs(wrapper);
objs.forEach(System.out::println);
}
/**
* 根据 entity 条件,查询全部记录(并翻页)
*/
@Test
public void selectPage() {
QueryWrapper<User> wrapper = Wrappers.query();
wrapper.gt("age", 18);
Page<User> page = userMapper.selectPage(Page.of(1, 2), wrapper);
page.getRecords().forEach(System.out::println);
}
/**
* 根据 entity 条件,查询全部记录(并翻页)
* 返回结果参考selectMaps的解释
*/
@Test
public void selectMapsPage() {
QueryWrapper<User> wrapper = Wrappers.query();
wrapper.gt("age", 18);
Page<Map<String, Object>> page = userMapper.selectMapsPage(Page.of(1, 2), wrapper);
page.getRecords().forEach(System.out::println);
}
/**
* 根据 Wrapper 条件,查询总记录数
*/
@Test
public void selectCount() {
QueryWrapper<User> wrapper = Wrappers.query();
wrapper.gt("age", 18);
Long count = userMapper.selectCount(wrapper);
System.out.println(count);
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# 参考
官方文档 (opens new window) 源码 (opens new window)
# 感谢
您好,如果文档能帮助到您,希望可以满足作者的小小虚荣心,在源码的项目上点一个小小的star ♥️
← 代码生成器 增删改查(service) →