有一些简简单单的数据库增删改查还需要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);
}
}
标签:IService,MybatisPlus,继承,default,boolean,user,return,entityList
From: https://blog.csdn.net/moshengqin/article/details/139772728