修复菜单、角色删除时,缓存未刷新的问题
parent
3583109f90
commit
9209e8da1c
|
@ -1,12 +1,12 @@
|
||||||
package cn.iocoder.yudao.module.system.dal.mysql.permission;
|
package cn.iocoder.yudao.module.system.dal.mysql.permission;
|
||||||
|
|
||||||
import cn.iocoder.yudao.framework.mybatis.core.enums.SqlConstants;
|
|
||||||
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
|
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
|
||||||
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
|
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.permission.vo.menu.MenuListReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.permission.vo.menu.MenuListReqVO;
|
||||||
import cn.iocoder.yudao.module.system.dal.dataobject.permission.MenuDO;
|
import cn.iocoder.yudao.module.system.dal.dataobject.permission.MenuDO;
|
||||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
import org.apache.ibatis.annotations.Select;
|
||||||
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -28,9 +28,7 @@ public interface MenuMapper extends BaseMapperX<MenuDO> {
|
||||||
.eqIfPresent(MenuDO::getStatus, reqVO.getStatus()));
|
.eqIfPresent(MenuDO::getStatus, reqVO.getStatus()));
|
||||||
}
|
}
|
||||||
|
|
||||||
default boolean selectExistsByUpdateTimeAfter(Date maxUpdateTime) {
|
@Select("SELECT id FROM system_menu WHERE update_time > #{maxUpdateTime} LIMIT 1")
|
||||||
return selectOne(new LambdaQueryWrapper<MenuDO>().select(MenuDO::getId)
|
MenuDO selectExistsByUpdateTimeAfter(Date maxUpdateTime);
|
||||||
.gt(MenuDO::getUpdateTime, maxUpdateTime).last(SqlConstants.LIMIT1)) != null;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,9 +7,8 @@ import cn.iocoder.yudao.framework.mybatis.core.query.QueryWrapperX;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.permission.vo.role.RoleExportReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.permission.vo.role.RoleExportReqVO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.permission.vo.role.RolePageReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.permission.vo.role.RolePageReqVO;
|
||||||
import cn.iocoder.yudao.module.system.dal.dataobject.permission.RoleDO;
|
import cn.iocoder.yudao.module.system.dal.dataobject.permission.RoleDO;
|
||||||
import com.baomidou.mybatisplus.annotation.InterceptorIgnore;
|
|
||||||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
import org.apache.ibatis.annotations.Select;
|
||||||
import org.springframework.lang.Nullable;
|
import org.springframework.lang.Nullable;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
@ -45,10 +44,7 @@ public interface RoleMapper extends BaseMapperX<RoleDO> {
|
||||||
return selectList(new LambdaQueryWrapperX<RoleDO>().inIfPresent(RoleDO::getStatus, statuses));
|
return selectList(new LambdaQueryWrapperX<RoleDO>().inIfPresent(RoleDO::getStatus, statuses));
|
||||||
}
|
}
|
||||||
|
|
||||||
@InterceptorIgnore(tenantLine = "true") // 该方法忽略多租户。原因:该方法被异步 task 调用,此时获取不到租户编号
|
@Select("SELECT id FROM system_role WHERE update_time > #{maxUpdateTime} LIMIT 1")
|
||||||
default boolean selectExistsByUpdateTimeAfter(Date maxUpdateTime) {
|
RoleDO selectExistsByUpdateTimeAfter(Date maxUpdateTime);
|
||||||
return selectOne(new QueryWrapper<RoleDO>().select("id")
|
|
||||||
.gt("update_time", maxUpdateTime).last("LIMIT 1")) != null;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -120,7 +120,7 @@ public class MenuServiceImpl implements MenuService {
|
||||||
if (maxUpdateTime == null) { // 如果更新时间为空,说明 DB 一定有新数据
|
if (maxUpdateTime == null) { // 如果更新时间为空,说明 DB 一定有新数据
|
||||||
log.info("[loadMenuIfUpdate][首次加载全量菜单]");
|
log.info("[loadMenuIfUpdate][首次加载全量菜单]");
|
||||||
} else { // 判断数据库中是否有更新的菜单
|
} else { // 判断数据库中是否有更新的菜单
|
||||||
if (!menuMapper.selectExistsByUpdateTimeAfter(maxUpdateTime)) {
|
if (menuMapper.selectExistsByUpdateTimeAfter(maxUpdateTime) == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
log.info("[loadMenuIfUpdate][增量加载全量菜单]");
|
log.info("[loadMenuIfUpdate][增量加载全量菜单]");
|
||||||
|
|
|
@ -116,7 +116,7 @@ public class RoleServiceImpl implements RoleService {
|
||||||
if (maxUpdateTime == null) { // 如果更新时间为空,说明 DB 一定有新数据
|
if (maxUpdateTime == null) { // 如果更新时间为空,说明 DB 一定有新数据
|
||||||
log.info("[loadRoleIfUpdate][首次加载全量角色]");
|
log.info("[loadRoleIfUpdate][首次加载全量角色]");
|
||||||
} else { // 判断数据库中是否有更新的角色
|
} else { // 判断数据库中是否有更新的角色
|
||||||
if (!roleMapper.selectExistsByUpdateTimeAfter(maxUpdateTime)) {
|
if (roleMapper.selectExistsByUpdateTimeAfter(maxUpdateTime) == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
log.info("[loadRoleIfUpdate][增量加载全量角色]");
|
log.info("[loadRoleIfUpdate][增量加载全量角色]");
|
||||||
|
|
Loading…
Reference in New Issue