Re: view - Mailing list pgsql-general

From Adrian Klaver
Subject Re: view
Date
Msg-id 55EEEBA6.507@aklaver.com
Whole thread Raw
In response to Re: view  (Melvin Davidson <melvin6925@gmail.com>)
List pgsql-general
On 09/08/2015 06:44 AM, Melvin Davidson wrote:
>  >ERROR:  permission denied for relation sub_item
>
> So obviously, the user doing the select on the view (ie: YOU)  does not
> have SELECT permission on table sub_item.

It is more subtle then that:

test=# select current_user;
  current_user
--------------
  postgres


test=# create table sub_item (id int, fld_1 varchar);

test=> \c - aklaver

test=> select current_user;
  current_user
--------------
  aklaver

test=> create view sub_view as select * from sub_item;
CREATE VIEW


public | sub_item           | table | postgres
public | sub_view           | view  | aklaver


test=> select * from sub_view ;
ERROR:  permission denied for relation sub_item

test=> \c - postgres


test=# select current_user;
  current_user
--------------
  postgres


test=# select * from sub_view ;
ERROR:  permission denied for relation sub_item

test=# alter  view sub_view owner to postgres;
ALTER VIEW

test=# select * from sub_view ;
  id | fld_1
----+-------
(0 rows)


It is the view owner that determines the permissions of what can be
selected. The catch is it is possible to create a view with a query it
cannot run as the user it is created by.

>
> On Tue, Sep 8, 2015 at 8:19 AM, Ramesh T <rameshparnanditech@gmail.com
> <mailto:rameshparnanditech@gmail.com>> wrote:
>
>     HI ,
>              I have view .when i try to select view ,it had return
>       select * from art;
>     ERROR:  permission denied for relation sub_item
>     SQL state: 42501
>
>
>
>
> --
> *Melvin Davidson*
> I reserve the right to fantasize.  Whether or not you
> wish to share my fantasy is entirely up to you.


--
Adrian Klaver
adrian.klaver@aklaver.com


pgsql-general by date:

Previous
From: Adrian Klaver
Date:
Subject: Re: view
Next
From: James Keener
Date:
Subject: Re: Anyone interested in a Pittsburgh-area Postgres users'