日常开发中有这中场景,一个用户有多个角色,一个角色又有多个菜单,想查出一个用户的所有菜单.除了常见的关联查询之外,更使用的应该是利用myBatis的resultMap来实现一次查询出多个结果集,缺点:每次组装结果集实际上是重新调用一次连接池,查询大量的数据时会造成资源浪费和效率不高. 首先声明一个BaseresultMapDetail,对应的映射实体类为SysMember,整个resultMap类似这样: <resultMap id="BaseResultMapDetail" t
索引 意图 结构 参与者 适用性 效果 相关模式 实现 实现方式(一):Role Object 的示例实现. 意图 通过明确地附加角色对象到目标对象中,以使对象可以适配不同的客户需求.每个角色对象都代表着目标对象在客户上下文中的一种角色.每种上下文都存在于特定的应用程序中,因此可使对象在不同的应用程序间解耦. Adapt an object to different client’s needs through transparently attached role objects, each
最近在处理数据库的用户权限问题,之前惯性思维,觉得给用户授权RESOURCE权限之后,用户的一般权限都会有,等到发现用户有RESOURCE角色,却没有创建视图的权限之后,才发现这部分还是一知半解啊,所以此处整理了一下相关的CONNECT角色和RESOURCE角色的内容. 一般情况下,在新建数据库用户后,都会习惯性的给用户授权CONNECT角色和RESOURCE角色: GRANT connect,resource TO 用户; 但是拥有这两个角色的用户都拥有什么权限呢?可以使用如下语句查看一下:
Role Object(角色对象) 索引 意图 结构 参与者 适用性 效果 相关模式 实现 实现方式(一):Role Object 的示例实现. 意图 通过明确地附加角色对象到目标对象中,以使对象可以适配不同的客户需求.每个角色对象都代表着目标对象在客户上下文中的一种角色.每种上下文都存在于特定的应用程序中,因此可使对象在不同的应用程序间解耦. Adapt an object to different client’s needs through transparently attached r
1.继承的权限只是继承该组的表的权限,用户对应的管理员权限则不会被继承. 2.inherit权限是说本角色是否继承别人的权限,而不是本权限能否被别的角色继承. postgres=# create role test0 createdb createrole login; CREATE ROLE postgres=# \du List of roles Role name | Attributes | Member of -----------+------------------------
splitOn参数:用来指定列为分隔列,之前的列为前一对象,之后的列为后一对象. lookup 用来保存中间处理结果,可以理解为将结果归组出Group对象,并为其RightsList添加内容, 注意:lookup中添加的是临时定义的Group对象,并在循环中将此对象从lookup中取出,为其RightsList添加Rights class Rights { public string ID{get;set;} public string Name{get;set;} } class Group
--查询帐户的状态select username,account_status from dba_users where username='SCOTT'; --创建用户create user john identified by johndefault tablespace usersquota 5m | unlimited on users --为新用户授予权限grant connect to john grant resouce to john alter user john quota
Oracle关于用户.权限.角色简单使用 创建数据库用户(在system用户下)create user 用户名 identified by 密码; 授权grant 权限名 to 用户名; 查看当前用户权限select * from session_privs; 移除权限revoke 权限 session from 用户名; 用户解锁/锁定alter user 用户名 account unlock/lock; 角色:权限组,多种权限的集合,将角色赋予某个用户时即是将其包含权限一次性赋予该用户:常用