我们有一个group
和user permission
表如下:
Group (group_id,name)
01 | G1
02 | G2
03 | G3
04 | G4
UserPermission (userid,group_id,active)
User1 | 01 | 1
User1 | 02 | 1
User2 | 01 | 1
User2 | 02 | 1
User2 | 03 | 1
User2 | 04 | 1
..
UserN | xx | 1
每个User都拥有一个Group的权限。
但是 UserPermission 表中缺少某些用户的某些权限。
问题是为表中存在的所有用户插入那些缺少的组权限条目 UserPermission
。
所以我想出的查询是(粗略的)
insert into UserPermission
select distinct userid, '03', 1 from UserPermission
where userid not in (
select userid from UserPermission where group_id = '03'
)
这是因为Group 03
..
其他组的用户缺少插入权限。
有没有更好的方法来编写上述查询。如何优化?