List roleMenuPOs = roleService.findRoleMenusByRoleId(roleUserPO.getRoleid()); if (roleMenuPOs == null) { return"当用户所在角色没有设置菜单!"; }
List menuPOLis = new ArrayList(); for (RoleMenuPO roleMenuPO : roleMenuPOs) { menuPOLis.add(menuService.findMenuById(roleMenuPO.getMenuid())); } return menuPOLis;
上面这例子放在这里这样一对比是不是有感觉了,如果还不够强烈请在往下看看。
项目需求中同样也有一个这样的要求,需要罗列特定角色在特定部门下的用户,SQL 写法。
select a.* from user a LEFT JOIN role_user b on a.UUID = b.userid LEFT JOIN orga_user c on a.uuid = c.userid where b.ROLEID = 'c9845b33973511e6acede16e8241c0fe' and c.ORGAID = '75284c22973211e6acede16e8241c0fe'
同样撸段相同逻辑的面向对象代码逻辑。
List userPO1s = roleService.findUsersByRoleId("角色ID"); if (userPO1s == null) { return"当前角色没有添加用户!"; }
List userPO2s = orgaService.findUsersByOrgaId("组织机构ID"); if (userPO2s == null) { return"当前机构没有添加用户!"; }
List userPOList = new ArrayList(); for (UserPO userPO1 : userPO1s) { for (UserPO userPO2 : userPO2s) { if (userPO1.getUuid().equals(userPO2.getUuid())) { userPOList.add(userPO1); break; } } } return userPOList;