文章目录
- 前言
- 一、使用示例
- 二、使用提示
- 总结
前言
Db Kit 是 Mybatis-Plus 提供的一个工具类,它允许开发者通过静态调用的方式执行 CRUD 操作,从而避免了在 Spring 环境下可能出现的 Service 循环注入问题,简化了代码,提升了开发效率。
Db Kit 的完整使用方式可以参考官方测试用例。
- 使用 Db Kit 前,需要确保项目中已注入对应实体的 BaseMapper。
- 当参数为 Wrapper 时,需要在 Wrapper 中传入 Entity 或者 EntityClass,以便寻找对应的 Mapper。
- 不建议在循环中频繁调用 Db Kit 的方法,如果是批量操作,建议先将数据构造好,然后使用
Db.saveBatch(数据)
等批量方法进行保存。
一、使用示例
// 假设有一个 User 实体类和对应的 BaseMapper// 根据 id 查询单个实体
User user = Db.getById(1L, User.class);// 根据 id 查询多个实体
List<User> userList = Db.listByIds(Arrays.asList(1L, 2L, 3L), User.class);// 根据条件构造器查询
LambdaQueryWrapper<User> queryWrapper = Wrappers.lambdaQuery(User.class).eq(User::getStatus, "active");
List<User> activeUsers = Db.list(queryWrapper);// 插入新实体
User newUser = new User();
newUser.setUsername("newUser");
newUser.setAge(25);
boolean isInserted = Db.insert(newUser);// 根据 id 更新实体
User updateUser = new User();
updateUser.setId(1L);
updateUser.setUsername("updatedUser");
boolean isUpdated = Db.updateById(updateUser);// 根据条件构造器更新
LambdaUpdateWrapper<User> updateWrapper = Wrappers.lambdaUpdate(User.class).set(User::getAge, 30).eq(User::getUsername, "updatedUser");
boolean isUpdatedByWrapper = Db.update(null, updateWrapper);// 根据 id 删除实体
boolean isDeleted = Db.removeById(1L,User.class);// 根据条件构造器删除
LambdaDeleteWrapper<User> deleteWrapper = Wrappers.lambdaDelete(User.class).eq(User::getStatus, "inactive");
boolean isDeletedByWrapper = Db.remove(deleteWrapper);// 批量插入
List<User> batchUsers = Arrays.asList(new User("user1", 20),new User("user2", 22),new User("user3", 24)
);
boolean isBatchInserted = Db.saveBatch(batchUsers);// 批量更新
List<User> batchUpdateUsers = Arrays.asList(new User(1L, "user1", 21),new User(2L, "user2", 23),new User(3L, "user3", 25)
);
boolean isBatchUpdated = Db.updateBatchById(batchUpdateUsers);
插入方法由insert
改为save
LambdaDeleteWrapper
已被移除,使用LambdaUpdateWrapper
执行删除时抛出异常:- com.baomidou.mybatisplus.core.exceptions.MybatisPlusException: java.lang.Long Not Found TableInfoCache.
,使用Db.removeById(1L,User.class);
二、使用提示
- Db Kit 提供了一系列静态方法,可以直接调用进行数据库操作,无需通过 Service 层,简化了代码结构。
- 在使用 Db Kit 时,确保传入的参数正确,特别是当使用 Wrapper 时,需要指定实体类或实体对象。
- 对于批量操作,如批量插入或更新,建议使用 Db Kit 提供的批量方法,以提高效率。
- 避免在循环中频繁调用 Db Kit 的方法,这可能会导致性能问题。
通过使用 Db Kit,开发者可以更加高效地执行数据库操作,同时保持代码的简洁性和可读性。这种工具类尤其适合于简单的 CRUD 操作,可以大大减少重复代码的编写。
总结
回到顶部