Обсуждение: BUG #1964: Role membership error
The following bug has been logged online: Bug reference: 1964 Logged by: Kevin Walker Email address: kwalker@ameritrade.com PostgreSQL version: 8.1 beta 3 Operating system: Windows XP Description: Role membership error Details: I created a group role called dbadmin and assigned it the privileges that I wanted. I then created a new login role and attempted to add this new login as a member in the group role. The following error is generated in pgAdmin III and when the same steps are performed manually. ERROR: role "dbadmin" is a member of role "kw" The message suggests that the login role "kw" is already a member of group role "dbadmin" which is not the case. Using the alter group command also produces the same error. This problem is occurring on the build for Windows. I have not tested this process on a Linux build yet.
Kevin Walker wrote: > > The following bug has been logged online: > > Bug reference: 1964 > Logged by: Kevin Walker > Email address: kwalker@ameritrade.com > PostgreSQL version: 8.1 beta 3 > Operating system: Windows XP > Description: Role membership error > Details: > > I created a group role called dbadmin and assigned it the privileges that I > wanted. I then created a new login role and attempted to add this new login > as a member in the group role. The following error is generated in pgAdmin > III and when the same steps are performed manually. > > ERROR: role "dbadmin" is a member of role "kw" > > The message suggests that the login role "kw" is already a member of group > role "dbadmin" which is not the case. Using the alter group command also > produces the same error. > > This problem is occurring on the build for Windows. I have not tested this > process on a Linux build yet. What were you trying, exactly? It worked for me: test=> CREATE ROLE dbadmin; CREATE ROLE test=> CREATE ROLE kw; CREATE ROLE test=> GRANT dbadmin TO kw; GRANT ROLE -- Bruce Momjian | http://candle.pha.pa.us pgman@candle.pha.pa.us | (610) 359-1001 + If your life is a hard drive, | 13 Roberts Road + Christ can be your backup. | Newtown Square, Pennsylvania 19073
"Kevin Walker" <kwalker@ameritrade.com> writes: > ERROR: role "dbadmin" is a member of role "kw" > The message suggests that the login role "kw" is already a member of group > role "dbadmin" which is not the case. I think you are reading it backwards. You're probably accidentally trying to set up circular role memberships, which isn't allowed. Observe: regression=# create role dbadmin; CREATE ROLE regression=# create role kw; CREATE ROLE regression=# grant kw to dbadmin; GRANT ROLE regression=# grant kw to dbadmin; NOTICE: role "dbadmin" is already a member of role "kw" GRANT ROLE regression=# grant dbadmin to kw; ERROR: role "dbadmin" is a member of role "kw" Note that re-granting is only a NOTICE not an ERROR. regards, tom lane