MybatisPlus之继承IService

有一些简简单单的数据库增删改查还需要Service到Mapper一步步地来吗?

答案是否定地,甚至代码都不用实现哦。

这就是因为IService接口提供了一些基础功能的实现

IService和ServiceImpl

IService只是一个接口,它并不能实现功能,如果你的service的接口继承它,继承过来的只是接口没有功能

public interface IUserService extends IService<User> 

接口继承时要指明实体类型,不然都不知道你要操作的对象是啥。

上面提到了继承的只是接口,没有功能,但官方还给出来针对IService的ServeImpl的功能实现,只需你的USerServiceImpl去继承它就OK了

public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IUserService

其中要指明你的Mapper和你的实体类型,这个实体类型和接口需要的实体类型要用到的一样,而这个Mapper可以通过查看源码发现是BaseMapper

public class ServiceImpl<M extends BaseMapper<T>, T> implements IService<T>

这个ServeImpl的原理呢就是将简单数据库操作呢给你封装好,通过继承的BaseMapper对数据库操作。

BaseMapper再提一嘴,他就是封装了大量的单表的数据访问层代码的编写增删改查的功能,可以快速调用实现数据库数据的改写。

ServiceImpl的功能

我们可以从IService的源码看看它实现了哪些功能,代码有点多直接看一部分。

  @Transactional(
        rollbackFor = {Exception.class}
    )
    default boolean saveBatch(Collection<T> entityList) {
        return this.saveBatch(entityList, 1000);
    }

    boolean saveBatch(Collection<T> entityList, int batchSize);

    @Transactional(
        rollbackFor = {Exception.class}
    )
    default boolean saveOrUpdateBatch(Collection<T> entityList) {
        return this.saveOrUpdateBatch(entityList, 1000);
    }

    boolean saveOrUpdateBatch(Collection<T> entityList, int batchSize);

    default boolean removeById(Serializable id) {
        return SqlHelper.retBool(this.getBaseMapper().deleteById(id));
    }

    default boolean removeById(Serializable id, boolean useFill) {
        throw new UnsupportedOperationException("不支持的方法!");
    }

    default boolean removeById(T entity) {
        return SqlHelper.retBool(this.getBaseMapper().deleteById(entity));
    }

    default boolean removeByMap(Map<String, Object> columnMap) {
        Assert.notEmpty(columnMap, "error: columnMap must not be empty", new Object[0]);
        return SqlHelper.retBool(this.getBaseMapper().deleteByMap(columnMap));
    }

    default boolean remove(Wrapper<T> queryWrapper) {
        return SqlHelper.retBool(this.getBaseMapper().delete(queryWrapper));
    }

    default boolean removeByIds(Collection<?> list) {
        return CollectionUtils.isEmpty(list) ? false : SqlHelper.retBool(this.getBaseMapper().deleteBatchIds(list));
    }

我们可以看到有一个@Transaction的注解,是为了数据库的事务回滚,确保数据库操作全部成功的,

rollbackFor = {Exception.class}

这个意思是当这个方法抛出任何 Exception(或其子类)时,事务将被回滚。

然后就是接口的功能声明

不同的功能类型有不同的前缀,可以通过前缀快速找到所需要的功能

  • save新增
  • get 查询单行
  • remove 删除
  • update修改
  • list 查询集合
  • page 分页

Service的测试

@SpringBootTest
class IUserServiceTest {

    @Autowired
    private IUserService userService;

    @Test
    void testSaveUser(){
        User user = new User();
        //user.setId(5L);
        user.setUsername("nxq");
        user.setPassword("123");
        user.setPhone("12345678999");
        user.setInfo("111");
        user.setCreateTime(LocalDateTime.now());
        user.setUpdateTime(LocalDateTime.now());
        userService.save(user);
    }
}

  • 11
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值