# 增删改查

提示

本章节主要讲解运用MP通用增删改查。案例以springboot融合mybatis-plus的搭建结构为基础,请按照教程操作 或者参考源码 (opens new window)@123

#

这里就提供了一个默认方法 参考 官方文档 (opens new window)


img.png

@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

#

有四个方法参考 官方文档 (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个方法参考 官方文档 (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

#

一共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

# 参考

官方文档 (opens new window) 源码 (opens new window)

# 感谢

您好,如果文档能帮助到您,希望可以满足作者的小小虚荣心,在源码的项目上点一个小小的star ♥️

Last Updated: 3/1/2024, 2:20:42 PM