如何高效获取用户被授权的分级结构,并支持分页查询?
mysql 高效获取用户被授权的分级结构
在复杂的授权结构下,查询用户被授权的分级结构十分重要。本文将探讨如何有效率地从 mysql 数据库中获取用户被授权的 f、e 和 d 列表,并支持分页功能。
需求分析
用户通过不同授权模式可获授权:
- [1] 全部授权 d、e、f
- [2] 授权 d,包括 d 下所有 e 和 f
- [3] 授权 d > e,包括 e 下所有 f
- [4] 授权 d > e > f
- [5] 授权 area,包括所有属于 area 的 f,跨 d,跨 d > e
- [6] 授权 d 下的 area ,含 d 下所有在 area 的 f,跨 d > e
- [7] 授权 d > e 下的 area ,含 e 下所有在 area 的 f
查询策略
针对用户被授权的 f 列表,数量较多,需要分页,且去重。可采用以下查询策略:
select f.f_id, f.f_name, f.f_area from p join f on p.f_id = f.f_id or p.f_id = 0 where p.u_id = @user_id and (p.d_id = f.d_id or p.d_id = 0) and (p.e_id = f.e_id or p.e_id = 0) and (p.a_code = f.f_area or p.a_code = "") order by f.f_id limit x, y
其中,x 为起始索引,y 为每页的数量。
对于用户被授权的 e 和 d 列表,可采用类似查询策略:
-- E 列表查询 SELECT E.E_id, E.E_name FROM P JOIN E ON P.E_id = E.E_id OR P.E_id = 0 WHERE P.U_id = @user_id AND (P.D_id = E.D_id OR P.D_id = 0) ORDER BY E.E_id LIMIT x, y -- D 列表查询 SELECT D.D_id, D.D_name FROM P JOIN D ON P.D_id = D.D_id OR P.D_id = 0 WHERE P.U_id = @user_id ORDER BY D.D_id LIMIT x, y
以上就是如何高效获取用户被授权的分级结构,并支持分页查询?的详细内容,更多请关注其它相关文章!