package com.iailab.module.system.dal.mysql.dept; import com.iailab.framework.common.pojo.PageResult; import com.iailab.framework.mybatis.core.mapper.BaseMapperX; import com.iailab.framework.mybatis.core.query.LambdaQueryWrapperX; import com.iailab.module.system.controller.admin.dept.vo.post.PostPageReqVO; import com.iailab.module.system.dal.dataobject.dept.PostDO; import org.apache.ibatis.annotations.Mapper; import java.util.Collection; import java.util.List; @Mapper public interface PostMapper extends BaseMapperX { default List selectList(Collection ids, Collection statuses) { return selectList(new LambdaQueryWrapperX() .inIfPresent(PostDO::getId, ids) .inIfPresent(PostDO::getStatus, statuses)); } default PageResult selectPage(PostPageReqVO reqVO) { return selectPage(reqVO, new LambdaQueryWrapperX() .likeIfPresent(PostDO::getCode, reqVO.getCode()) .likeIfPresent(PostDO::getName, reqVO.getName()) .eqIfPresent(PostDO::getStatus, reqVO.getStatus()) .orderByDesc(PostDO::getId)); } default PostDO selectByName(String name) { return selectOne(PostDO::getName, name); } default PostDO selectByCode(String code) { return selectOne(PostDO::getCode, code); } }