package cn.lihu.jh.module.system.dal.mysql.permission; 
 | 
  
 | 
import cn.lihu.jh.framework.common.pojo.PageResult; 
 | 
import cn.lihu.jh.framework.mybatis.core.dataobject.BaseDO; 
 | 
import cn.lihu.jh.framework.mybatis.core.mapper.BaseMapperX; 
 | 
import cn.lihu.jh.framework.mybatis.core.query.LambdaQueryWrapperX; 
 | 
import cn.lihu.jh.module.system.controller.admin.permission.vo.role.RolePageReqVO; 
 | 
import cn.lihu.jh.module.system.dal.dataobject.permission.RoleDO; 
 | 
import org.apache.ibatis.annotations.Mapper; 
 | 
import org.springframework.lang.Nullable; 
 | 
  
 | 
import java.util.Collection; 
 | 
import java.util.List; 
 | 
  
 | 
@Mapper 
 | 
public interface RoleMapper extends BaseMapperX<RoleDO> { 
 | 
  
 | 
    default PageResult<RoleDO> selectPage(RolePageReqVO reqVO) { 
 | 
        return selectPage(reqVO, new LambdaQueryWrapperX<RoleDO>() 
 | 
                .likeIfPresent(RoleDO::getName, reqVO.getName()) 
 | 
                .likeIfPresent(RoleDO::getCode, reqVO.getCode()) 
 | 
                .eqIfPresent(RoleDO::getStatus, reqVO.getStatus()) 
 | 
                .betweenIfPresent(BaseDO::getCreateTime, reqVO.getCreateTime()) 
 | 
                .orderByAsc(RoleDO::getSort)); 
 | 
    } 
 | 
  
 | 
    default RoleDO selectByName(String name) { 
 | 
        return selectOne(RoleDO::getName, name); 
 | 
    } 
 | 
  
 | 
    default RoleDO selectByCode(String code) { 
 | 
        return selectOne(RoleDO::getCode, code); 
 | 
    } 
 | 
  
 | 
    default List<RoleDO> selectListByStatus(@Nullable Collection<Integer> statuses) { 
 | 
        return selectList(RoleDO::getStatus, statuses); 
 | 
    } 
 | 
  
 | 
} 
 |