X-Original-To: pgsql-bugs-postgresql.org@localhost.postgresql.org Received: from localhost (unknown [200.46.204.144]) by svr1.postgresql.org (Postfix) with ESMTP id 52C195294C for ; Thu, 21 Apr 2005 09:22:58 -0300 (ADT) Received: from svr1.postgresql.org ([200.46.204.71]) by localhost (av.hub.org [200.46.204.144]) (amavisd-new, port 10024) with ESMTP id 61117-08 for ; Thu, 21 Apr 2005 12:22:52 +0000 (GMT) Received: from svr2.postgresql.org (svr2.postgresql.org [65.19.161.25]) by svr1.postgresql.org (Postfix) with ESMTP id E0650536EB for ; Thu, 21 Apr 2005 09:22:50 -0300 (ADT) Received: by svr2.postgresql.org (Postfix, from userid 80) id 15E03F0B53; Thu, 21 Apr 2005 13:19:44 +0100 (BST) To: pgsql-bugs@postgresql.org Subject: BUG #1610: rewrite rule and sequence From: "Olleg Samoylov" Message-Id: <20050421121944.15E03F0B53@svr2.postgresql.org> Date: Thu, 21 Apr 2005 13:19:44 +0100 (BST) X-Virus-Scanned: by amavisd-new at hub.org X-Spam-Status: No, hits=0 tagged_above=0 required=5 tests= X-Spam-Level: X-Archive-Number: 200504/138 X-Sequence-Number: 11590 The following bug has been logged online: Bug reference: 1610 Logged by: Olleg Samoylov Email address: olleg@mipt.ru PostgreSQL version: 7.4.7 Operating system: Linux debian-amd64 Description: rewrite rule and sequence Details: Rule on view can't insert in table with "serial" field under not owner. Need grant privilege on sequence explicitly. How reproduce: olleg=> create table f (pk serial, f integer); NOTICE: CREATE TABLE will create implicit sequence "f_pk_seq" for "serial" column "f.pk" CREATE TABLE olleg=> create view v as select * from t; ERROR: relation "t" does not exist olleg=> drop table f; DROP TABLE olleg=> create table t (pk serial, f integer); NOTICE: CREATE TABLE will create implicit sequence "t_pk_seq" for "serial" column "t.pk" CREATE TABLE olleg=> create view v as select * from t; CREATE VIEW olleg=> create rule r as on insert to v do instead insert into t(f) values (new.f); CREATE RULE olleg=> grant select,insert on t to bill; GRANT olleg=> \c - bill You are now connected as new user "bill". olleg=> insert into t (f) values (0); ERROR: permission denied for sequence t_pk_seq