接口和实现类都继承: 如果你让你的服务接口继承
IService
,并让你的服务实现类继承ServiceImpl
,那么你的服务接口将明确地列出所有可用的 CRUD 方法。只继承
ServiceImpl
: 如果你只让你的服务实现类继承ServiceImpl
,你仍然可以使用所有IService
的方法,但这些方法不会明确地在你的服务接口中列出。
@Override
@Transactional(rollbackFor = Exception.class)
public ResponseDTO<String> deleteUnitManagementById(Integer id) {
unitManagementDao.deleteById(id);
this.removeById(id);
return ResponseDTO.succ();
}
@Slf4j
@Service
public class UnitManagementServiceImpl extends ServiceImpl<UnitManagementDao, UnitManagementsEntity> implements UnitManagementService {
public interface UnitManagementService extends IService<UnitManagementsEntity>{
@Mapper
public interface UnitManagementDao extends BaseMapper<UnitManagementsEntity> {
使用 Integer
而不是原始类型 int
有其优点,特别是在处理可能返回 null
值的查询时。原始类型 int
不能接受 null
值,而包装类 Integer
可以。
public interface UnitManagementMapper extends BaseMapper<UnitManagement> {
Integer countDistinctUnitLevels();
}
1. 使用 lambdaQuery
方法查询:
public List<CmsContent> findByUrl(String url) {
return lambdaQuery().eq(CmsContent::getUrl, url).list();
}
2. 在 Mapper 接口中添加自定义查询方法,然后在 Service 中调用这个方法:
3. 使用基础的 baseMapper
:
public List<CmsContent> findByUrl(String url) {
QueryWrapper<CmsContent> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("url", url);
return baseMapper.selectList(queryWrapper);
}
4.QueryWrapper和lambdaQuery有什么区别吗
LambdaQuery (LambdaQueryWrapper, LambdaQueryChainWrapper)
- 类型安全:使用 Java 8 的 Lambda 表达式,它是类型安全的。如果你更改了数据模型,编译器会立即告诉你哪里出了问题。
- 易于重构:由于类型安全,重构代码会更容易和更安全。
- 现代语法:使用 Java 8 Lambda 表达式使代码更简洁。
- 或者更简洁的链式调用
List<User> users = new LambdaQueryChainWrapper<>(userMapper)
.eq(User::getName, "John")
.list();
LambdaQueryWrapper<User> lambdaQuery = Wrappers.lambdaQuery();
lambdaQuery.eq(User::getName, "John");
List<User> users = userMapper.selectList(lambdaQuery);
工具包
hutool包里的ObjectUtil.isNull和ObjectUtil.isEmpty的区别
ObjectUtils 和StringUtils工具包的区别
Spring Framework:ObjectUtils.isEmpty(unitLevel)