package com.iailab.module.system.dal.mysql.tenant; 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.tenant.vo.tenant.TenantPageReqVO; import com.iailab.module.system.dal.dataobject.tenant.TenantDO; import org.apache.ibatis.annotations.Mapper; import java.util.List; /** * 租户 Mapper * * @author iailab */ @Mapper public interface TenantMapper extends BaseMapperX { default PageResult selectPage(TenantPageReqVO reqVO) { return selectPage(reqVO, new LambdaQueryWrapperX() .likeIfPresent(TenantDO::getName, reqVO.getName()) .likeIfPresent(TenantDO::getContactName, reqVO.getContactName()) .likeIfPresent(TenantDO::getContactMobile, reqVO.getContactMobile()) .eqIfPresent(TenantDO::getStatus, reqVO.getStatus()) .betweenIfPresent(TenantDO::getCreateTime, reqVO.getCreateTime()) .orderByDesc(TenantDO::getId)); } default TenantDO selectByName(String name) { return selectOne(TenantDO::getName, name); } default TenantDO selectByWebsite(String website) { return selectOne(TenantDO::getWebsite, website); } default Long selectCountByPackageId(Long packageId) { return selectCount(TenantDO::getPackageId, packageId); } default List selectListByPackageId(Long packageId) { return selectList(TenantDO::getPackageId, packageId); } }