7818 lines
358 KiB
Plaintext
7818 lines
358 KiB
Plaintext
From ronz@ravensfield.com Tue May 22 17:35:37 2001
|
||
Return-path: <ronz@ravensfield.com>
|
||
Received: from carp.ravensfield.com ([209.41.227.126])
|
||
by candle.pha.pa.us (8.10.1/8.10.1) with ESMTP id f4MLZaQ17913
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 May 2001 17:35:37 -0400 (EDT)
|
||
Received: from coho.ravensfield.com (coho [209.41.227.117])
|
||
by carp.ravensfield.com (Postfix) with SMTP
|
||
id 5C2A9800D; Tue, 22 May 2001 16:46:38 -0500 (EST)
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
From: Andrew Rawnsley <ronz@ravensfield.com>
|
||
Organization: Ravensfield Geographic
|
||
To: Bruce Momjian <pgman@candle.pha.pa.us>
|
||
Subject: Re: [GENERAL] Queries across multiple databases (was: SELECT from a table in another database).
|
||
Date: Tue, 22 May 2001 17:37:25 -0400
|
||
X-Mailer: KMail [version 1.2]
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>
|
||
References: <200105220437.f4M4bUA00539@candle.pha.pa.us>
|
||
In-Reply-To: <200105220437.f4M4bUA00539@candle.pha.pa.us>
|
||
MIME-Version: 1.0
|
||
Message-ID: <01052217372504.01367@coho.ravensfield.com>
|
||
Content-Transfer-Encoding: 8bit
|
||
Status: ORr
|
||
|
||
On Tuesday 22 May 2001 12:37am, Bruce Momjian wrote:
|
||
> Can you send me a little sample of SCHEMA use?
|
||
|
||
Pardon if this is more long-winded or tangental than you are looking for...
|
||
|
||
What may beconfusing many people (not excluding myself from time to time) is
|
||
that cross-schema queries may have nothing to do with cross-database queries,
|
||
which is an entirely different kettle of trout.... SCHEMAs as used by at
|
||
least by Oracle and Sybase are nothing more than users/object owners (I have
|
||
no experience with DB2 or Informix, or anything more exotic than that).
|
||
|
||
Just off the top of my head, what would satisfy most people would be to be
|
||
able to refer to objects as OWNER.OBJECT, with owner being 'within' the
|
||
database (i.e. DATABASE.OWNER.OBJECT, which is how Sybase does it. Oracle has
|
||
no 'database' parallel like that). Whether you do it Oracle-fashion and use
|
||
the term SCHEMA for owner pretty universally or Sybase fashion and just pay
|
||
lip service to the word doesn't really matter (unless there is a standards
|
||
compliance issue).
|
||
|
||
As to creating schemas...In Oracle you have to execute the CREATE SCHEMA
|
||
AUTHORIZATION <user> while logged in as that user before you can add objects
|
||
under that user's ownership. While it seems trivial, if you have a situation
|
||
where you do not want to grant a user session rights, you have to grant them
|
||
session rights, log in as them, execute CREATE SCHEMA..., then revoke the
|
||
session rights. Bah. A table created by user X in schema Y is also owned by
|
||
user Y, and its user Y that has to have many of the object rights to create
|
||
that table.
|
||
|
||
In Sybase, its essentially the same except the only real use for the CREATE
|
||
SCHEMA command is for compliance and to group some DDL commands together.
|
||
Other than that, Sybase always refers to schemas as owners. You don't have to
|
||
execute CREATE SCHEMA... to create objects - you just need the rights. I've
|
||
never used it at least - the only thing I see in it is eliminating the need
|
||
to type 'go' after every DDL command.
|
||
|
||
As for examples from Oracle space -
|
||
|
||
Here is a foreign key reference with delete triggers from a table in
|
||
schema/user PROJECT to tables in schemas/users SERVICES and WEBCAL:
|
||
|
||
CREATE TABLE PROJECT.tasks_users (
|
||
<EFBFBD> <20>event_id INTEGER REFERENCES WEBCAL.tasks(event_id) ON DELETE CASCADE,
|
||
<EFBFBD> <20>user_id VARCHAR2(25) REFERENCES SERVICES.users(user_id) ON DELETE CASCADE,
|
||
<EFBFBD> <20>confirmed CHAR(1),
|
||
<EFBFBD> <20>PRIMARY KEY (event_id,user_id)
|
||
);
|
||
|
||
A join between tables in would be
|
||
SELECT <20> A.SAMPLE_ID,
|
||
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A.CONCENTRATION,
|
||
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> A.CASNO,
|
||
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> B.PARAMETER,
|
||
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> C.DESCRIPTION AS STYPE
|
||
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> FROM HAI.RESULTS A, SAMPLETRACK.PARAMETERS B,
|
||
SAMPLETRACK.SAMPLE_TYPE C
|
||
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> WHERE A.CASNO = B.CASNO AND A.SAMPLE_TYPE = B.SAMPLE_TYPE
|
||
|
||
In both Oracle and Sybase, all the objects are in the same 'database'
|
||
(instance in Oracle), as I assume they would be in Postgres. There is I
|
||
assume a name space issue - one should be able to create a FOO.BAR and a
|
||
BAR.BAR in the same database.
|
||
|
||
> I may be adding it to
|
||
> 7.2 inside the same code that maps temp table names to real tables.
|
||
>
|
||
|
||
Excellent! I see light at the end of the tunnel (I will say the Postgres
|
||
maintainers are among the most solidly competent around - one never has any
|
||
real doubts about the system's progress).
|
||
|
||
--
|
||
Regards,
|
||
|
||
Andrew Rawnsley
|
||
Ravensfield Digital Resource Group, Ltd.
|
||
(740) 587-0114
|
||
www.ravensfield.com
|
||
|
||
From reedstrm@rice.edu Wed May 23 10:59:42 2001
|
||
Return-path: <reedstrm@rice.edu>
|
||
Received: from ece.rice.edu (ece.rice.edu [128.42.4.34])
|
||
by candle.pha.pa.us (8.10.1/8.10.1) with ESMTP id f4NExgQ05774
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 May 2001 10:59:42 -0400 (EDT)
|
||
Received: from wallace.ece.rice.edu (wallace.ece.rice.edu [128.42.12.154])
|
||
by ece.rice.edu (Postfix) with ESMTP id A419F68A0E
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 May 2001 09:59:36 -0500 (CDT)
|
||
Received: from reedstrm by wallace.ece.rice.edu with local (Exim 3.22 #1 (Debian))
|
||
id 152a41-0006E5-00
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 May 2001 09:56:41 -0500
|
||
Date: Wed, 23 May 2001 09:56:41 -0500
|
||
From: "Ross J. Reedstrom" <reedstrm@rice.edu>
|
||
To: Bruce Momjian <pgman@candle.pha.pa.us>
|
||
Subject: Re: [HACKERS] Re: [GENERAL] Re: [GENERAL] Queries across multiple databases ?(was: SELECT from a table in another database).
|
||
Message-ID: <20010523095641.D23741@rice.edu>
|
||
References: <004c01c0e214$ce6c4800$1001a8c0@archonet.com> <200105221131.f4MBVIc28574@candle.pha.pa.us>
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Disposition: inline
|
||
User-Agent: Mutt/1.3.17i
|
||
In-Reply-To: <200105221131.f4MBVIc28574@candle.pha.pa.us>; from pgman@candle.pha.pa.us on Tue, May 22, 2001 at 07:31:18AM -0400
|
||
Status: ORr
|
||
|
||
Bruce -
|
||
Around the first of the year, I started playing around with a schema
|
||
implementation. As you may recall, my first crack at changing file storage
|
||
names about a year ago was motivated by the need to avoid collisions
|
||
once schema were available.
|
||
|
||
Anyway, now that Vadim has removed a lot of the internal dependence
|
||
on relname for keeping track of relations, using the new relfinenode
|
||
many places relname used to be used, it seems to me that adding a
|
||
parallel schemaname to all the data structures that use relname isn't
|
||
as cumbersome as Peter might think. I hadn't tackled the relcache yet:
|
||
perhaps concatenating the schemaname and relname to use as the hash key
|
||
is the way to go for that.
|
||
|
||
Unfortunately, all that code is now 4 months old, and on my machine
|
||
at home. I has started with the rangetable entries, because hacked the
|
||
parser to allow 'SELECT * FROM schemaname.tablename' was easier than
|
||
'select schemaname.tablename.fieldname FROM', since the dot function
|
||
calling convention isn't allowed in the range list, while it is in the
|
||
target list.
|
||
|
||
I seem to recall tripping up on the query plan printer, of all things,
|
||
before other, paying work pushed it aside. I'll see if I can update that
|
||
code to the current tree, and send you something, if you'd like.
|
||
|
||
Ross
|
||
|
||
|
||
|
||
On Tue, May 22, 2001 at 07:31:18AM -0400, Bruce Momjian wrote:
|
||
> > > I'm not sure whether it is quite the way to do it, but I'd have a better
|
||
> > > time with things if I could span databases in a single request. Are
|
||
> > > there theoretical problems with spanning databases in a single query? Is
|
||
> > > it a feature of bad database design & implementation?
|
||
> >
|
||
> > I think the developers are planning full schema support for the relatively
|
||
> > near future (possibly even 7.2, but check the archives and see what's been
|
||
> > said). Although it looks easy to access a table from another database,
|
||
> > things can rapidly become more complicated as you start having to deal with
|
||
> > transactions, triggers, rules, constraints...
|
||
>
|
||
> Schema is on my radar screen for 7.2. I am waiting to do some research
|
||
> in what needs to be done, but my initial idea is to use the system cache
|
||
> to do namespace mapping, just like is done now for temp tables.
|
||
>
|
||
> --
|
||
> Bruce Momjian | http://candle.pha.pa.us
|
||
> pgman@candle.pha.pa.us | (610) 853-3000
|
||
> + If your life is a hard drive, | 830 Blythe Avenue
|
||
> + Christ can be your backup. | Drexel Hill, Pennsylvania 19026
|
||
>
|
||
> ---------------------------(end of broadcast)---------------------------
|
||
> TIP 2: you can get off all lists at once with the unregister command
|
||
> (send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M17793=candle.pha.pa.us=pgman@postgresql.org Fri Jan 18 19:40:47 2002
|
||
Return-path: <pgsql-hackers-owner+M17793=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0J0elU09208
|
||
for <pgman@candle.pha.pa.us>; Fri, 18 Jan 2002 19:40:47 -0500 (EST)
|
||
Received: (qmail 94886 invoked by alias); 19 Jan 2002 00:40:45 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 19 Jan 2002 00:40:45 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0J0TfV92793
|
||
for <pgsql-hackers@postgreSQL.org>; Fri, 18 Jan 2002 19:29:41 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0J0Th311096
|
||
for <pgsql-hackers@postgreSQL.org>; Fri, 18 Jan 2002 19:29:44 -0500 (EST)
|
||
To: pgsql-hackers@postgresql.org
|
||
Subject: [HACKERS] Schemas vs. PostQUEL: resolving qualified identifiers
|
||
Date: Fri, 18 Jan 2002 19:29:43 -0500
|
||
Message-ID: <11093.1011400183@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
I'm starting to think about how to do SQL-compatible schemas in Postgres.
|
||
|
||
One of the first issues that comes up is that Postgres has interpretations
|
||
of qualified (dotted) names that conflict with what the standard says to
|
||
do. This stuff is a hangover from Berkeley days and PostQUEL. Briefly,
|
||
since there are no schemas in PG, anytime we have a dotted name we know
|
||
that the first component *must* be a table name. Successive components are
|
||
then resolved as either column or function names applied to whatever we
|
||
have so far. For example,
|
||
|
||
a.b.c is equivalent to c(a.b) if c is a function
|
||
|
||
The equivalence works the other way too: you can write colname(tabname)
|
||
and it will be taken as tabname.colname (though this seems to work only
|
||
if tabname already has a rangetable entry).
|
||
|
||
This is not going to fly together with SQL92, which wants a.b.c to mean
|
||
schema a, table b, column c.
|
||
|
||
I believe we can resolve the conflict without breaking any cases that
|
||
are likely to be used much in practice. Here's my proposal:
|
||
|
||
First, I'd like to allow the notation "table.*" to be used as a function
|
||
argument, representing passing a whole-row value to a function (the
|
||
function's argument would be declared as the table rowtype). Presently
|
||
this is done by writing just the undecorated table name, but that is
|
||
ambiguous if the same name is also used as a column name in the query.
|
||
Also, we need this notation for use with qualified table names.
|
||
|
||
Having done that, we can resolve names appearing in expressions thus:
|
||
|
||
foo First try to resolve as unqualified column name;
|
||
if not found, try to resolve as unqualified table name
|
||
(in which case this is a whole-row value, equivalent
|
||
to foo.*).
|
||
|
||
foo.bar foo is an unqualified table name. Try first to resolve
|
||
bar as a column name of foo; if not found, try to resolve
|
||
bar as a function taking the rowtype of foo.
|
||
|
||
foo.bar.baz This refers to table bar in schema foo. baz is either
|
||
a column or function name, as above.
|
||
|
||
foo.bar.baz.quux Refers to table baz in schema bar in catalog foo.
|
||
quux is either a column or function name, as above.
|
||
|
||
foo.* foo is an unqualified table name; means whole-row value.
|
||
|
||
foo.bar.* Whole row of table bar in schema foo.
|
||
|
||
foo.bar.baz.* Whole row of table baz in schema bar in catalog foo.
|
||
|
||
The first two of these rules are the same as current behavior; the next
|
||
two are additions mandated by SQL92; the last three are a proposed
|
||
extension to allow unambiguous reference to whole-row values.
|
||
|
||
With these rules, we do not lose any functionality that we have now,
|
||
but some PostQUEL-ish constructs will need to be rewritten into an
|
||
equivalent form.
|
||
|
||
PostQUEL-isms that still work:
|
||
|
||
table.func equivalent to func(table.*)
|
||
|
||
func(table) equivalent to func(table.*), as long as table name
|
||
doesn't match any column name of the query
|
||
|
||
PostQUEL-isms that no longer work:
|
||
|
||
table.col.func Must rewrite as func(table.col)
|
||
|
||
table.func1.func2 Must rewrite as, eg, func2(func1(table.*))
|
||
|
||
While there are a couple of examples of the above two constructs in the
|
||
regression tests, I doubt they are used much in the real world.
|
||
|
||
Another PostQUEL-ism that I would like to remove is col(tab) to mean
|
||
tab.col; I'd prefer to restrict the function syntax to functions only.
|
||
We could continue to support this for unqualified table names, but
|
||
given the above rules it could not work for a qualified table name,
|
||
eg, col(schema.tab) would be misinterpreted. Again, it seems unlikely
|
||
that many people are using this, so we may as well try to regularize
|
||
the syntax as much as we can.
|
||
|
||
You may wonder why I'm still allowing the construction tab.func ---
|
||
why not get rid of that too? Well, mainly because I'd like to support
|
||
the Oracle-ish syntax for nextval: seqname.nextval. Together with the
|
||
desire not to break existing code unnecessarily, that seems a good enough
|
||
reason to leave it in.
|
||
|
||
Comments?
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M18054=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 14:15:06 2002
|
||
Return-path: <pgsql-hackers-owner+M18054=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NJF5U00389
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 14:15:05 -0500 (EST)
|
||
Received: (qmail 74462 invoked by alias); 23 Jan 2002 19:13:45 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 19:13:45 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NJ0Fl67761
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 14:00:15 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0NJ00f04506;
|
||
Wed, 23 Jan 2002 14:00:01 -0500 (EST)
|
||
To: Fernando Nasser <fnasser@redhat.com>
|
||
cc: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] Schemas vs. PostQUEL: resolving qualified identifiers
|
||
In-Reply-To: <3C4EFD15.882B0785@redhat.com>
|
||
References: <46C15C39FEB2C44BA555E356FBCD6FA42128D9@m0114.s-mxs.net> <2521.1011798379@sss.pgh.pa.us> <3C4EFD15.882B0785@redhat.com>
|
||
Comments: In-reply-to Fernando Nasser <fnasser@redhat.com>
|
||
message dated "Wed, 23 Jan 2002 13:12:37 -0500"
|
||
Date: Wed, 23 Jan 2002 14:00:00 -0500
|
||
Message-ID: <4503.1011812400@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Fernando Nasser <fnasser@redhat.com> writes:
|
||
> Tom Lane wrote:
|
||
>> Okay, but then how will you refer unambiguously to the rowtype object?
|
||
|
||
> What about casting with the keyord ROW?
|
||
> func(ROW table)
|
||
> always refers to the row-type of table "table" even if there is
|
||
> a column called "table".
|
||
|
||
Strikes me as gratuituously different from the way everything else is
|
||
done. We have .* and %ROWTYPE and so forth, and they're all suffixes.
|
||
The closest analogy to your ROW syntax is CAST, but it doesn't alter the
|
||
initial interpretation of its argument.
|
||
|
||
I was toying with the notion of inventing some new notation like
|
||
table.**
|
||
I don't like double-asterisk much, but maybe there's some other symbol
|
||
we could use here?
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18069=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 17:13:24 2002
|
||
Return-path: <pgsql-hackers-owner+M18069=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NMDOU16966
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 17:13:24 -0500 (EST)
|
||
Received: (qmail 49292 invoked by alias); 23 Jan 2002 22:13:23 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 22:13:23 -0000
|
||
Received: from cygnus.com (runyon.sfbay.redhat.com [205.180.230.5] (may be forged))
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0NLvFl45904
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 16:57:15 -0500 (EST)
|
||
(envelope-from fnasser@redhat.com)
|
||
Received: from redhat.com (totem.toronto.redhat.com [172.16.14.242])
|
||
by runyon.cygnus.com (8.8.7-cygnus/8.8.7) with ESMTP id NAA18180;
|
||
Wed, 23 Jan 2002 13:57:09 -0800 (PST)
|
||
Message-ID: <3C4F31B4.C7C9B2D6@redhat.com>
|
||
Date: Wed, 23 Jan 2002 16:57:08 -0500
|
||
From: Fernando Nasser <fnasser@redhat.com>
|
||
Organization: Red Hat , Inc. - Toronto
|
||
X-Mailer: Mozilla 4.78 [en] (X11; U; Linux 2.4.7-10smp i686)
|
||
X-Accept-Language: en
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] Schemas vs. PostQUEL: resolving qualified identifiers
|
||
References: <46C15C39FEB2C44BA555E356FBCD6FA42128D9@m0114.s-mxs.net> <2521.1011798379@sss.pgh.pa.us> <3C4EFD15.882B0785@redhat.com> <4503.1011812400@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> Fernando Nasser <fnasser@redhat.com> writes:
|
||
> > Tom Lane wrote:
|
||
> >> Okay, but then how will you refer unambiguously to the rowtype object?
|
||
>
|
||
> > What about casting with the keyord ROW?
|
||
> > func(ROW table)
|
||
> > always refers to the row-type of table "table" even if there is
|
||
> > a column called "table".
|
||
>
|
||
> Strikes me as gratuituously different from the way everything else is
|
||
> done. We have .* and %ROWTYPE and so forth, and they're all suffixes.
|
||
> The closest analogy to your ROW syntax is CAST, but it doesn't alter the
|
||
> initial interpretation of its argument.
|
||
>
|
||
|
||
I didn't mean literally that way, I just wanted to add a keyword for
|
||
solving ambiguity (when there is one).
|
||
|
||
You are right, it should be:
|
||
|
||
func(table%ROWTYPE)
|
||
|
||
|
||
|
||
|
||
--
|
||
Fernando Nasser
|
||
Red Hat - Toronto E-Mail: fnasser@redhat.com
|
||
2323 Yonge Street, Suite #300
|
||
Toronto, Ontario M4P 2C9
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 5: Have you checked our extensive FAQ?
|
||
|
||
http://www.postgresql.org/users-lounge/docs/faq.html
|
||
|
||
From pgsql-hackers-owner+M17920=candle.pha.pa.us=pgman@postgresql.org Mon Jan 21 16:45:17 2002
|
||
Return-path: <pgsql-hackers-owner+M17920=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0LLjHU16235
|
||
for <pgman@candle.pha.pa.us>; Mon, 21 Jan 2002 16:45:17 -0500 (EST)
|
||
Received: (qmail 38745 invoked by alias); 21 Jan 2002 21:43:19 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 21 Jan 2002 21:43:19 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0LLTql30573
|
||
for <pgsql-hackers@postgreSQL.org>; Mon, 21 Jan 2002 16:29:53 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0LLTrf11384
|
||
for <pgsql-hackers@postgreSQL.org>; Mon, 21 Jan 2002 16:29:53 -0500 (EST)
|
||
To: pgsql-hackers@postgresql.org
|
||
Subject: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Date: Mon, 21 Jan 2002 16:29:52 -0500
|
||
Message-ID: <11381.1011648592@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Continuing to think about implementing SQL schemas for 7.3 ...
|
||
|
||
Today's topic for discussion: which types of Postgres objects should
|
||
belong to schemas, and which ones should have other name scopes?
|
||
|
||
Relations (tables, indexes, views, sequences) clearly belong to schemas.
|
||
Since each relation has an associated datatype with the same name, it
|
||
seems that datatypes must belong to schemas as well. (Even if that
|
||
argument doesn't convince you, SQL99 says that user-defined datatypes
|
||
belong to schemas.) However the situation is murkier for other kinds of
|
||
objects.
|
||
|
||
Here are all the kinds of named objects that exist in Postgres today,
|
||
with some comments on whether they should belong to schemas or not:
|
||
|
||
relations Must be in schemas
|
||
types Must be in schemas
|
||
databases Databases contain schemas, not vice versa
|
||
users Users are cross-database, so not in schemas
|
||
groups User groups are cross-database, so not in schemas
|
||
languages Probably should not be in schemas
|
||
access methods Probably should not be in schemas
|
||
opclasses See below
|
||
operators See below
|
||
functions/procedures See below
|
||
aggregates Should treat same as regular functions
|
||
constraints See below
|
||
rules See below
|
||
triggers See below
|
||
NOTIFY conditions See below
|
||
|
||
Languages and access methods are not trivial to add to the system, so
|
||
there's not much risk of name conflicts, and no reason to make their name
|
||
scope less than global.
|
||
|
||
The situation is a lot murkier for operators and functions. These should
|
||
probably be treated alike, since operators are just syntactic sugar for
|
||
functions. I think the basic argument for making them schema-local is
|
||
that different users might conceivably want to define conflicting
|
||
functions or operators of the same name. Against that, however, there
|
||
are a number of reasons for wanting to keep these objects database-wide.
|
||
First off there are syntactic problems. Do you really want to write
|
||
A schemaname.+ B
|
||
to qualify an ambiguous "+" operator? Looks way too much like a syntax
|
||
error to me. Allowing this would probably turn a lot of simple syntax
|
||
errors into things that get past the grammar and end up producing truly
|
||
confusing error messages. Qualified function names also pose some
|
||
problems, not so much with
|
||
schemaname.function(args)
|
||
which seems reasonable, but with the Berkeley-derived syntax that allows
|
||
"foo.function" to mean "function(foo)" --- there's no way to squeeze a
|
||
schema-name for the function into that. (And you'll recall from my note
|
||
of the other day that we don't want to abandon this syntax entirely,
|
||
because people would like us to support "sequencename.nextval" for Oracle
|
||
compatibility.) Notice that we are not forced to make functions/operators
|
||
schema-local just because datatypes are, because overloading will save the
|
||
day. func(schema1.type1) and func(schema2.type1) are distinct functions
|
||
because the types are different, even if they live in the same function
|
||
namespace. Finally, SQL99 doesn't appear to think that operator and
|
||
function names are schema-local; though that may just be because it hasn't
|
||
got user-defined operators AFAICT.
|
||
|
||
I am leaning towards keeping functions/operators database-wide, but would
|
||
like to hear comments. Is there any real value in, eg, allowing different
|
||
users to define different "+" operators *on the same datatypes*?
|
||
|
||
Not sure about index opclasses. Given that datatype names are
|
||
schema-local, one can think of scenarios where two users define similar
|
||
datatypes and then try to use the same index opclass name for both.
|
||
But it seems pretty unlikely. I'd prefer to leave opclass names
|
||
database-wide for simplicity. Comments?
|
||
|
||
As for constraints, currently we only support table-level constraints,
|
||
and we do not enforce any uniqueness at all on their names; multiple
|
||
constraints for the same table can have the same name (and if so, ALTER
|
||
TABLE DROP CONSTRAINT drops all matching names). SQL92 requires named
|
||
constraints to have names that are unique within their schema, which is
|
||
okay for standalone assertions (which we haven't got) but seems quite
|
||
unnecessary for constraints attached to tables. And what's really odd,
|
||
it appears to allow a table constraint to belong to a different schema
|
||
than the table it is on! This is pretty bogus. I'd prefer to ignore the
|
||
part of the spec that says that table constraint names can be qualified
|
||
names, and either keep our existing behavior or require constraint names
|
||
to be unique per-table. Thoughts?
|
||
|
||
Rewrite rules are currently required to have a name unique within their
|
||
database. We clearly don't want that to still be true in the schema
|
||
environment. Personally I would like to make rules' names unique only
|
||
among rules on the same table (like we handle triggers). That would
|
||
mean an incompatible change in the syntax of DROP RULE: it'd have to
|
||
become DROP RULE rule ON table, much like DROP TRIGGER. Is that okay?
|
||
If not, probably we must make rulenames local to schemas and say they
|
||
implicitly belong to the schema of the associated table.
|
||
|
||
Triggers are already handled as being named uniquely among the triggers
|
||
of the same table. This behavior is fine with me, and doesn't need to
|
||
be changed for schema support.
|
||
|
||
I can see some advantage to considering NOTIFY condition names to be local
|
||
to a schema, but I can also see risks of breaking existing applications.
|
||
Currently, "NOTIFY foo" will signal to "LISTEN foo" even if the two
|
||
processes belong to different users. With an implicit schema qualifier
|
||
attached to foo, very likely this would fail to work. Since NOTIFY names
|
||
aren't officially registered anywhere, the implicit qualifier would have
|
||
to correspond to the front schema of one's schema search path, and there'd
|
||
be no way for such processes to communicate if their search paths didn't
|
||
match. I think people would end up always qualifying NOTIFY names with
|
||
a single schema name, which means we might as well continue to consider
|
||
them global. On the other hand, if you assume that NOTIFY names are often
|
||
the names of tables, it'd make sense to allow them to be qualified. Any
|
||
thoughts on this?
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M17929=candle.pha.pa.us=pgman@postgresql.org Mon Jan 21 19:13:39 2002
|
||
Return-path: <pgsql-hackers-owner+M17929=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0M0DcU03335
|
||
for <pgman@candle.pha.pa.us>; Mon, 21 Jan 2002 19:13:38 -0500 (EST)
|
||
Received: (qmail 78739 invoked by alias); 22 Jan 2002 00:12:48 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 00:12:48 -0000
|
||
Received: from corvette.mascari.com (dhcp065-024-158-068.columbus.rr.com [65.24.158.68])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0LNo9l76502
|
||
for <pgsql-hackers@postgresql.org>; Mon, 21 Jan 2002 18:50:09 -0500 (EST)
|
||
(envelope-from mascarm@mascari.com)
|
||
Received: from mascari.com (ferrari.mascari.com [192.168.2.1])
|
||
by corvette.mascari.com (8.9.3/8.9.3) with ESMTP id SAA26029
|
||
for <pgsql-hackers@postgresql.org>; Mon, 21 Jan 2002 18:45:34 -0500
|
||
Message-ID: <3C4CA81E.4D1D7BD9@mascari.com>
|
||
Date: Mon, 21 Jan 2002 18:45:34 -0500
|
||
From: Mike Mascari <mascarm@mascari.com>
|
||
X-Mailer: Mozilla 4.7 [en] (WinNT; I)
|
||
X-Accept-Language: en
|
||
MIME-Version: 1.0
|
||
To: pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <11381.1011648592@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> Continuing to think about implementing SQL schemas for 7.3 ...
|
||
>
|
||
> Today's topic for discussion: which types of Postgres objects should
|
||
> belong to schemas, and which ones should have other name scopes?
|
||
...
|
||
>
|
||
> I am leaning towards keeping functions/operators database-wide, but would
|
||
> like to hear comments. Is there any real value in, eg, allowing different
|
||
> users to define different "+" operators *on the same datatypes*?
|
||
|
||
With regard to functions, I believe they should be schema specific.
|
||
Oracle allows the creation of procedures/functions in specific schema.
|
||
User2 may then execute user1's function as:
|
||
|
||
EXECUTE user1.myfunction();
|
||
|
||
However, as you suggest, the fully qualified naming of functions gets
|
||
messy. So Oracle allows (and I think we would need) PUBLIC SYNONYMs.
|
||
This allows user1 to do:
|
||
|
||
CREATE TABLE employees(key integer, name VARCHAR(20));
|
||
|
||
CREATE SEQUENCE s;
|
||
|
||
CREATE PROCEDURE newemployee(n IN VARCHAR)
|
||
AS
|
||
BEGIN
|
||
INSERT INTO employees
|
||
SELECT s.nextval, n
|
||
FROM DUAL;
|
||
END;
|
||
/
|
||
|
||
GRANT INSERT ON employees TO user2;
|
||
GRANT EXECUTE ON newemployee TO user2;
|
||
CREATE PUBLIC SYNONYM newemployee FOR user1.newemployee;
|
||
|
||
Now, user2 just does:
|
||
|
||
EXECUTE newemployee(10);
|
||
|
||
|
||
In fact, with regard to the package discussion a while back, Oracle
|
||
allows this:
|
||
|
||
Database->Schema->Package->Procedure
|
||
|
||
and this:
|
||
|
||
Database->Schema->Procedure
|
||
|
||
and effectively this:
|
||
|
||
Database->Procedure via Database->PUBLIC Schema->Procedure
|
||
|
||
I really think that the main purpose of schemas is to prevent an
|
||
ill-informed or malicious user from engaging in unacceptable behavior.
|
||
By placing everything in schemas, it allows the Oracle DBA to have a
|
||
very fine-grained control over the ability of user1 to interfere with
|
||
user2. Before user1 above could pollute the global namespace, the dba
|
||
must have:
|
||
|
||
GRANT user1 CREATE PUBLIC SYNONYM
|
||
|
||
privilege, or created the synonym himself. This allows things like
|
||
pg_class to reside within their own schema, as well as all built-in
|
||
PostgreSQL functions. After the bootstrapping, PUBLIC SYNONYMs are
|
||
created for all of the system objects which should have global scope:
|
||
|
||
CREATE PUBLIC SYNONYM pg_class FOR system.pg_class;
|
||
CREATE PUBLIC SYNONYM abs(int) FOR system.abs(int);
|
||
|
||
One major benefit of Oracle is that the DBA, through the use of
|
||
STATEMENT privileges (i.e. GRANT CREATE TABLE to user1), resource
|
||
PROFILEs, and TABLESPACES can easily admin a database used by 20
|
||
different deparments and 1000 different users without the fear that one
|
||
might step on the other's toes. If the accounting department wants to
|
||
create an addtax() function, it shouldn't have to ask the receiving
|
||
deptartment to do so.
|
||
|
||
Just my thoughts,
|
||
|
||
Mike Mascari
|
||
mascarm@mascari.com
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M17928=candle.pha.pa.us=pgman@postgresql.org Mon Jan 21 19:13:39 2002
|
||
Return-path: <pgsql-hackers-owner+M17928=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0M0DcU03336
|
||
for <pgman@candle.pha.pa.us>; Mon, 21 Jan 2002 19:13:38 -0500 (EST)
|
||
Received: (qmail 78777 invoked by alias); 22 Jan 2002 00:12:50 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 00:12:50 -0000
|
||
Received: from student.gvsu.edu ([148.61.7.124])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0LNxBl77018
|
||
for <pgsql-hackers@postgreSQL.org>; Mon, 21 Jan 2002 18:59:12 -0500 (EST)
|
||
(envelope-from peter_e@gmx.net)
|
||
Received: from [148.61.250.18] [148.61.250.18] by student.gvsu.edu
|
||
with Novonyx SMTP Server $Revision: 1.3 $; Mon, 21 Jan 2002 18:59:14 -0500 (EDT)
|
||
Date: Mon, 21 Jan 2002 19:01:13 -0500 (EST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
X-Sender: <peter@peter.localdomain>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <11381.1011648592@sss.pgh.pa.us>
|
||
Message-ID: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane writes:
|
||
|
||
> languages Probably should not be in schemas
|
||
> access methods Probably should not be in schemas
|
||
> opclasses See below
|
||
> operators See below
|
||
> functions/procedures See below
|
||
> aggregates Should treat same as regular functions
|
||
> constraints See below
|
||
> rules See below
|
||
> triggers See below
|
||
> NOTIFY conditions See below
|
||
|
||
Remember that a schema is a named representation of ownership, so anything
|
||
that can be owned must be in a schema. (Unless you want to invent a
|
||
parallel universe for a different kind of ownership, which would be
|
||
incredibly confusing.) Also remember that we wanted to use schemas as a
|
||
way to prevent unprivileged users from creating anything by default. So
|
||
it would be much simpler if "everything" were in a schema.
|
||
|
||
I wouldn't worry so much about the invocation syntax -- if you don't like
|
||
ugly don't make ugly. For instance, if you add a user-defined operator
|
||
you would probably either put it in the same schema with the rest of your
|
||
project or put it in some sort of a global or default schema (to be
|
||
determined) to make it available to the whole system, my assumption being
|
||
that either way you don't need to qualify the operator. But the important
|
||
thing is that you *could* make cross-schema operator calls, say during
|
||
development or testing.
|
||
|
||
Consequentially, I opine that all of the things listed above should be in
|
||
a schema. (Although I don't have a strong opinion about notifications,
|
||
yet.)
|
||
|
||
> namespace. Finally, SQL99 doesn't appear to think that operator and
|
||
> function names are schema-local; though that may just be because it hasn't
|
||
> got user-defined operators AFAICT.
|
||
|
||
Check clause 10.4 <routine invocation>: routine names are (optionally)
|
||
schema qualified like everything else.
|
||
|
||
> Rewrite rules are currently required to have a name unique within their
|
||
> database. We clearly don't want that to still be true in the schema
|
||
> environment. Personally I would like to make rules' names unique only
|
||
> among rules on the same table (like we handle triggers). That would
|
||
> mean an incompatible change in the syntax of DROP RULE: it'd have to
|
||
> become DROP RULE rule ON table, much like DROP TRIGGER. Is that okay?
|
||
> If not, probably we must make rulenames local to schemas and say they
|
||
> implicitly belong to the schema of the associated table.
|
||
|
||
I'd rather make the opposite change (make trigger names schema-global)
|
||
because that aligns with SQL99 and it would make more sense for overall
|
||
consistency (e.g., you can't have indexes with the same names on different
|
||
tables). The syntax change would also be backward compatible. I think
|
||
either way, schema-global or table-global namespace, can be argued to be
|
||
more useful or more confusion-prone, so I side with the standard on this
|
||
one.
|
||
|
||
--
|
||
Peter Eisentraut peter_e@gmx.net
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M17932=candle.pha.pa.us=pgman@postgresql.org Mon Jan 21 20:14:13 2002
|
||
Return-path: <pgsql-hackers-owner+M17932=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0M1ECU11565
|
||
for <pgman@candle.pha.pa.us>; Mon, 21 Jan 2002 20:14:12 -0500 (EST)
|
||
Received: (qmail 88800 invoked by alias); 22 Jan 2002 01:14:11 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 01:14:11 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0M16kl87933
|
||
for <pgsql-hackers@postgreSQL.org>; Mon, 21 Jan 2002 20:06:47 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0M16Uf12242;
|
||
Mon, 21 Jan 2002 20:06:30 -0500 (EST)
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
cc: pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain>
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain>
|
||
Comments: In-reply-to Peter Eisentraut <peter_e@gmx.net>
|
||
message dated "Mon, 21 Jan 2002 19:01:13 -0500"
|
||
Date: Mon, 21 Jan 2002 20:06:30 -0500
|
||
Message-ID: <12239.1011661590@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> Remember that a schema is a named representation of ownership, so anything
|
||
> that can be owned must be in a schema. (Unless you want to invent a
|
||
> parallel universe for a different kind of ownership, which would be
|
||
> incredibly confusing.)
|
||
|
||
I don't buy that premise. It's true that SQL92 equates ownership of a
|
||
schema with ownership of the objects therein, but AFAICS we have no hope
|
||
of being forward-compatible with existing database setups (wherein there
|
||
can be multiple tables of different ownership all in a single namespace)
|
||
if we don't allow varying ownership within a schema. I think we can
|
||
arrange things so that we are upward compatible with both SQL92 and
|
||
the old way. Haven't worked out details yet though.
|
||
|
||
Have to run, more later.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M17933=candle.pha.pa.us=pgman@postgresql.org Mon Jan 21 20:42:40 2002
|
||
Return-path: <pgsql-hackers-owner+M17933=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0M1geU12708
|
||
for <pgman@candle.pha.pa.us>; Mon, 21 Jan 2002 20:42:40 -0500 (EST)
|
||
Received: (qmail 92393 invoked by alias); 22 Jan 2002 01:42:38 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 01:42:38 -0000
|
||
Received: from p566.codebydesign.com (cx950878-a.fed1.sdca.home.com [24.11.158.40])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0M1cZl91431
|
||
for <pgsql-hackers@postgresql.org>; Mon, 21 Jan 2002 20:38:35 -0500 (EST)
|
||
(envelope-from pharvey@codebydesign.com)
|
||
Received: from p12.codebydesign.com (p12.codebydesign.com [192.168.1.27])
|
||
by p566.codebydesign.com (8.11.1/8.11.1) with SMTP id g0M2mmt12179;
|
||
Mon, 21 Jan 2002 18:48:53 -0800
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
From: Peter Harvey <pharvey@codebydesign.com>
|
||
Organization: CodeByDesign
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Date: Mon, 21 Jan 2002 17:39:05 -0800
|
||
X-Mailer: KMail [version 1.2]
|
||
cc: pgsql-hackers@postgresql.org
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us>
|
||
In-Reply-To: <12239.1011661590@sss.pgh.pa.us>
|
||
MIME-Version: 1.0
|
||
Message-ID: <02012117390500.02279@p12.codebydesign.com>
|
||
Content-Transfer-Encoding: 8bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
FYI: Applications like Data Architect would benefit from a consistent and
|
||
complete interface to the schema. For example; I found that we had to bypass
|
||
the DD views which exist (as I recall) because they did not give us all
|
||
information we needed. So we selected stuff from the system tables directly.
|
||
Yucky. Sorry I can not recall details but thought that I would mention this
|
||
here. The MySQL 'SHOW' statements seem to work pretty well and shields us
|
||
from changes to the system tables.
|
||
|
||
Peter
|
||
|
||
> I don't buy that premise. It's true that SQL92 equates ownership of a
|
||
> schema with ownership of the objects therein, but AFAICS we have no hope
|
||
> of being forward-compatible with existing database setups (wherein there
|
||
> can be multiple tables of different ownership all in a single namespace)
|
||
> if we don't allow varying ownership within a schema. I think we can
|
||
> arrange things so that we are upward compatible with both SQL92 and
|
||
> the old way. Haven't worked out details yet though.
|
||
>
|
||
> Have to run, more later.
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M17966=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 10:53:20 2002
|
||
Return-path: <pgsql-hackers-owner+M17966=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MFrJU05739
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 10:53:20 -0500 (EST)
|
||
Received: (qmail 83537 invoked by alias); 22 Jan 2002 15:53:00 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 15:53:00 -0000
|
||
Received: from cygnus.com (runyon.sfbay.redhat.com [205.180.230.5] (may be forged))
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0MFoql80523
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 10:50:52 -0500 (EST)
|
||
(envelope-from fnasser@redhat.com)
|
||
Received: from redhat.com (rtl.sfbay.redhat.com [205.180.230.21])
|
||
by runyon.cygnus.com (8.8.7-cygnus/8.8.7) with ESMTP id HAA09903;
|
||
Tue, 22 Jan 2002 07:50:43 -0800 (PST)
|
||
Message-ID: <3C4D8A39.FF79CDC4@redhat.com>
|
||
Date: Tue, 22 Jan 2002 10:50:17 -0500
|
||
From: Fernando Nasser <fnasser@redhat.com>
|
||
Organization: Red Hat Canada
|
||
X-Mailer: Mozilla 4.78 [en] (X11; U; Linux 2.4.9-13 i686)
|
||
X-Accept-Language: en
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> > Remember that a schema is a named representation of ownership, so anything
|
||
> > that can be owned must be in a schema. (Unless you want to invent a
|
||
> > parallel universe for a different kind of ownership, which would be
|
||
> > incredibly confusing.)
|
||
>
|
||
> I don't buy that premise. It's true that SQL92 equates ownership of a
|
||
> schema with ownership of the objects therein, but AFAICS we have no hope
|
||
> of being forward-compatible with existing database setups (wherein there
|
||
> can be multiple tables of different ownership all in a single namespace)
|
||
> if we don't allow varying ownership within a schema. I think we can
|
||
> arrange things so that we are upward compatible with both SQL92 and
|
||
> the old way. Haven't worked out details yet though.
|
||
>
|
||
|
||
Peter is right. Schemas is just a practical way of creating things
|
||
under
|
||
the same authorization-id + crating a namespace so that different
|
||
authorization-ids can have objects with the same (unqualified name).
|
||
|
||
Quoting Date (pg. 221): "The schema authID for a given schema identifies
|
||
the owner of that schema (and hence the owner of everything described by
|
||
that schema also)."
|
||
|
||
It is very important that we reach a conclusion on this as it simplifies
|
||
things a lot.
|
||
|
||
Regards,
|
||
Fernando
|
||
|
||
|
||
P.S.: That is why I was telling you that, except for the namespace part,
|
||
we already have the groundwork for Entry-level SQL-Schemas (where the
|
||
schema is always the authorization-id of the creator) -- it is just
|
||
a question of handling the "owner" appropriately.
|
||
|
||
|
||
--
|
||
Fernando Nasser
|
||
Red Hat Canada Ltd. E-Mail: fnasser@redhat.com
|
||
2323 Yonge Street, Suite #300
|
||
Toronto, Ontario M4P 2C9
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M17973=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 11:26:13 2002
|
||
Return-path: <pgsql-hackers-owner+M17973=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MGQCU09218
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 11:26:12 -0500 (EST)
|
||
Received: (qmail 4629 invoked by alias); 22 Jan 2002 16:25:41 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 16:25:41 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0MGGTl95123
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 11:16:29 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0MGGBf15342;
|
||
Tue, 22 Jan 2002 11:16:11 -0500 (EST)
|
||
To: Fernando Nasser <fnasser@redhat.com>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C4D8A39.FF79CDC4@redhat.com>
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us> <3C4D8A39.FF79CDC4@redhat.com>
|
||
Comments: In-reply-to Fernando Nasser <fnasser@redhat.com>
|
||
message dated "Tue, 22 Jan 2002 10:50:17 -0500"
|
||
Date: Tue, 22 Jan 2002 11:16:11 -0500
|
||
Message-ID: <15339.1011716171@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Fernando Nasser <fnasser@redhat.com> writes:
|
||
> Tom Lane wrote:
|
||
>> I don't buy that premise. It's true that SQL92 equates ownership of a
|
||
>> schema with ownership of the objects therein, but AFAICS we have no hope
|
||
>> of being forward-compatible with existing database setups (wherein there
|
||
>> can be multiple tables of different ownership all in a single namespace)
|
||
>> if we don't allow varying ownership within a schema.
|
||
|
||
> Quoting Date (pg. 221): "The schema authID for a given schema identifies
|
||
> the owner of that schema (and hence the owner of everything described by
|
||
> that schema also)."
|
||
|
||
Yes, I know what the spec says. I also think we'll have a revolt on our
|
||
hands if we don't make it possible for existing Postgres applications to
|
||
continue working as they have in the past --- and that means allowing
|
||
tables of different ownerships to be accessible in a single namespace.
|
||
|
||
Although I haven't thought through the details yet, it seems to me that
|
||
a solution exists along these lines:
|
||
|
||
1. The creator of an object owns it. (With some special cases, eg the
|
||
superuser should be able to create a schema owned by someone else.)
|
||
|
||
2. Whether you can create an object in a schema that is owned by someone
|
||
else depends on permissions attached to the schema. By default only
|
||
the owner of a schema can create anything in it.
|
||
|
||
3. SQL92-compatible behavior is achieved when everyone has their own
|
||
schema and they don't grant each other create-in-schema rights.
|
||
Backwards-compatible behavior is achieved when everyone uses a
|
||
shared "public" schema.
|
||
|
||
We'd probably need GUC variable(s) to make it possible to choose which
|
||
behavior is the default. I haven't thought much about exactly what
|
||
knobs should be provided. I do think we will want at least these two
|
||
knobs:
|
||
|
||
1. A "search path" that is an ordered list of schemas to look in
|
||
when trying to resolve an unqualified name.
|
||
|
||
2. A "default schema" variable that identifies the schema to create
|
||
objects in, if a fully qualified name is not given.
|
||
|
||
The default creation location shouldn't be hardwired to equal the
|
||
front of the search path, because the front item of the search path
|
||
is probably always going to be a backend-local temporary schema
|
||
(this is where we'll create temporary tables).
|
||
|
||
The most dumbed-down version of this that would work is to reduce the
|
||
search path to just a fixed list of three locations: temp schema, a
|
||
selectable default schema (which is also the default creation location),
|
||
and a system schema (where pg_class and friends live). But a
|
||
user-settable path wouldn't be any more effort to support, and might
|
||
offer some useful capability.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M17976=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 12:04:19 2002
|
||
Return-path: <pgsql-hackers-owner+M17976=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MH4IU12377
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 12:04:18 -0500 (EST)
|
||
Received: (qmail 20616 invoked by alias); 22 Jan 2002 17:04:13 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 17:04:13 -0000
|
||
Received: from cygnus.com (runyon.sfbay.redhat.com [205.180.230.5] (may be forged))
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0MGiKl15781
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 11:44:20 -0500 (EST)
|
||
(envelope-from fnasser@redhat.com)
|
||
Received: from redhat.com (rtl.sfbay.redhat.com [205.180.230.21])
|
||
by runyon.cygnus.com (8.8.7-cygnus/8.8.7) with ESMTP id IAA14751;
|
||
Tue, 22 Jan 2002 08:44:15 -0800 (PST)
|
||
Message-ID: <3C4D96C5.80BBF764@redhat.com>
|
||
Date: Tue, 22 Jan 2002 11:43:49 -0500
|
||
From: Fernando Nasser <fnasser@redhat.com>
|
||
Organization: Red Hat Canada
|
||
X-Mailer: Mozilla 4.78 [en] (X11; U; Linux 2.4.9-13 i686)
|
||
X-Accept-Language: en
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us> <3C4D8A39.FF79CDC4@redhat.com> <15339.1011716171@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> > Quoting Date (pg. 221): "The schema authID for a given schema identifies
|
||
> > the owner of that schema (and hence the owner of everything described by
|
||
> > that schema also)."
|
||
>
|
||
> Yes, I know what the spec says. I also think we'll have a revolt on our
|
||
> hands if we don't make it possible for existing Postgres applications to
|
||
> continue working as they have in the past --- and that means allowing
|
||
> tables of different ownerships to be accessible in a single namespace.
|
||
>
|
||
|
||
But them it is not SQL-Schemas. Call it something else, "packages"
|
||
for instance. The standard has lots of rules and other considerations
|
||
all around the document that depend on schemas have the meaning they
|
||
assigned to it.
|
||
|
||
If someone wants to really make use of SQL-Schemas, he/she will need to
|
||
reorg the database anyway, which will probably mean dumping the data,
|
||
massaging the DLL and recreating it. I guess most users of SQL-Schemas
|
||
will be people creating new databases.
|
||
|
||
For the current users, (based on your idea below) a default behavior of
|
||
searching the current-AuthID schema, them the "default" schema them
|
||
"any"
|
||
schema will probably make things work.
|
||
|
||
Fernando
|
||
|
||
P.S.: Note that the standard has no GRANTs for SCHEMAs themselves; all
|
||
GRANTS go to the specific objects as before.
|
||
|
||
|
||
> Although I haven't thought through the details yet, it seems to me that
|
||
> a solution exists along these lines:
|
||
>
|
||
> 1. The creator of an object owns it. (With some special cases, eg the
|
||
> superuser should be able to create a schema owned by someone else.)
|
||
>
|
||
> 2. Whether you can create an object in a schema that is owned by someone
|
||
> else depends on permissions attached to the schema. By default only
|
||
> the owner of a schema can create anything in it.
|
||
>
|
||
> 3. SQL92-compatible behavior is achieved when everyone has their own
|
||
> schema and they don't grant each other create-in-schema rights.
|
||
> Backwards-compatible behavior is achieved when everyone uses a
|
||
> shared "public" schema.
|
||
>
|
||
> We'd probably need GUC variable(s) to make it possible to choose which
|
||
> behavior is the default. I haven't thought much about exactly what
|
||
> knobs should be provided. I do think we will want at least these two
|
||
> knobs:
|
||
>
|
||
> 1. A "search path" that is an ordered list of schemas to look in
|
||
> when trying to resolve an unqualified name.
|
||
>
|
||
> 2. A "default schema" variable that identifies the schema to create
|
||
> objects in, if a fully qualified name is not given.
|
||
>
|
||
> The default creation location shouldn't be hardwired to equal the
|
||
> front of the search path, because the front item of the search path
|
||
> is probably always going to be a backend-local temporary schema
|
||
> (this is where we'll create temporary tables).
|
||
>
|
||
> The most dumbed-down version of this that would work is to reduce the
|
||
> search path to just a fixed list of three locations: temp schema, a
|
||
> selectable default schema (which is also the default creation location),
|
||
> and a system schema (where pg_class and friends live). But a
|
||
> user-settable path wouldn't be any more effort to support, and might
|
||
> offer some useful capability.
|
||
>
|
||
> regards, tom lane
|
||
>
|
||
> ---------------------------(end of broadcast)---------------------------
|
||
> TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
> subscribe-nomail command to majordomo@postgresql.org so that your
|
||
> message can get through to the mailing list cleanly
|
||
|
||
--
|
||
Fernando Nasser
|
||
Red Hat Canada Ltd. E-Mail: fnasser@redhat.com
|
||
2323 Yonge Street, Suite #300
|
||
Toronto, Ontario M4P 2C9
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M17976=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 12:04:19 2002
|
||
Return-path: <pgsql-hackers-owner+M17976=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MH4IU12378
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 12:04:18 -0500 (EST)
|
||
Received: (qmail 20627 invoked by alias); 22 Jan 2002 17:04:13 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 17:04:13 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0MGpjl18339
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 11:51:45 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0MGpUf15641;
|
||
Tue, 22 Jan 2002 11:51:30 -0500 (EST)
|
||
To: Fernando Nasser <fnasser@redhat.com>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C4D96C5.80BBF764@redhat.com>
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us> <3C4D8A39.FF79CDC4@redhat.com> <15339.1011716171@sss.pgh.pa.us> <3C4D96C5.80BBF764@redhat.com>
|
||
Comments: In-reply-to Fernando Nasser <fnasser@redhat.com>
|
||
message dated "Tue, 22 Jan 2002 11:43:49 -0500"
|
||
Date: Tue, 22 Jan 2002 11:51:30 -0500
|
||
Message-ID: <15638.1011718290@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Fernando Nasser <fnasser@redhat.com> writes:
|
||
> But them it is not SQL-Schemas. Call it something else, "packages"
|
||
> for instance. The standard has lots of rules and other considerations
|
||
> all around the document that depend on schemas have the meaning they
|
||
> assigned to it.
|
||
|
||
Where? And are there any cases where it really matters?
|
||
|
||
> If someone wants to really make use of SQL-Schemas, he/she will need to
|
||
> reorg the database anyway, which will probably mean dumping the data,
|
||
> massaging the DLL and recreating it. I guess most users of SQL-Schemas
|
||
> will be people creating new databases.
|
||
|
||
No doubt. That still leaves us with the problem of providing
|
||
backward-compatible behavior in an engine that is going to be designed
|
||
to support schemas. I'm not sure what you think the implementation of
|
||
schemas is going to look like --- but I think it's not going to be
|
||
something that can be turned off or ignored. Every table is going to
|
||
belong to some schema, and the old behavior has to be available within
|
||
that framework.
|
||
|
||
We are not working in a vacuum here, and that means that "implement
|
||
the specification and nothing but" is not a workable design approach.
|
||
We are going to end up with something that does the things SQL92 asks
|
||
for, but does other things too.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M17980=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 15:34:09 2002
|
||
Return-path: <pgsql-hackers-owner+M17980=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MKY7U05934
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 15:34:07 -0500 (EST)
|
||
Received: (qmail 77926 invoked by alias); 22 Jan 2002 20:33:26 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 20:33:26 -0000
|
||
Received: from cygnus.com (runyon.sfbay.redhat.com [205.180.230.5] (may be forged))
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0MKUrl76871
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 15:30:54 -0500 (EST)
|
||
(envelope-from fnasser@redhat.com)
|
||
Received: from redhat.com (rtl.sfbay.redhat.com [205.180.230.21])
|
||
by runyon.cygnus.com (8.8.7-cygnus/8.8.7) with ESMTP id MAA09466;
|
||
Tue, 22 Jan 2002 12:30:46 -0800 (PST)
|
||
Message-ID: <3C4DCBDB.689D7201@redhat.com>
|
||
Date: Tue, 22 Jan 2002 15:30:20 -0500
|
||
From: Fernando Nasser <fnasser@redhat.com>
|
||
Organization: Red Hat Canada
|
||
X-Mailer: Mozilla 4.78 [en] (X11; U; Linux 2.4.9-13 i686)
|
||
X-Accept-Language: en
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us> <3C4D8A39.FF79CDC4@redhat.com> <15339.1011716171@sss.pgh.pa.us> <3C4D96C5.80BBF764@redhat.com> <15638.1011718290@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
OK, so the proposal is that we dissociate the ownership from the
|
||
namespace when we implement our version of SQL-Schemas, right?
|
||
This way an object will have both an owner and a schema (while in
|
||
the standard they are the same thing).
|
||
|
||
The important is not much to accommodate someone who is creating
|
||
schemas (a new thing, so objects can be created the "right" way)
|
||
but rather to accommodate current code that does not use schemas
|
||
and have several owners for the objects (which would all fall
|
||
into a "default" schema). Can you agree with that?
|
||
|
||
I was looking to see if we choose the proper defaults and search paths
|
||
and the "default" schema we could make it look for SQL-compliant code
|
||
as if it was a vanilla SQL-Schemas implementation.
|
||
|
||
To support the current database schema definitions (without SQL-Schemas
|
||
and with different owners), things would be created with the current
|
||
user authorization id and will have its name defined in the "default"
|
||
SQL-Schema
|
||
namespace. Also, when referring to an object if the name is not
|
||
qualified
|
||
with the schema name, the search would go through the schema with the
|
||
current authorization id (as required by the std) and proceed to check
|
||
the "default" schema.
|
||
|
||
The only problem in the scenario above is that the standard says that
|
||
when creating objects and not specifying the schema the schema name
|
||
should be assumed to be the current user authorization id (or whatever
|
||
authorization id the code is running as). In our case it would go to
|
||
the default schema. If someone wants the SQL std behavior then, he/she
|
||
must create things inside a CREATE SCHEMA statement or explicitly
|
||
qualify
|
||
with the schema name the objects being created. Can we live with that?
|
||
Will we pass the conformance tests? (I saw tests that test the schema
|
||
name
|
||
that is assumed when referencing but I do not recall seeing one that
|
||
tests
|
||
what is assumed on creation -- things I saw were all created inside
|
||
CREATE SCHEMA statements. Note, also, that passing the NIST tests
|
||
doesn't
|
||
make us compliant if we know that we are doing something different than
|
||
what is specified -- it just means that we got away with it :-)
|
||
|
||
|
||
--
|
||
Fernando Nasser
|
||
Red Hat Canada Ltd. E-Mail: fnasser@redhat.com
|
||
2323 Yonge Street, Suite #300
|
||
Toronto, Ontario M4P 2C9
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M17982=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 15:46:46 2002
|
||
Return-path: <pgsql-hackers-owner+M17982=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MKkhU07389
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 15:46:44 -0500 (EST)
|
||
Received: (qmail 82732 invoked by alias); 22 Jan 2002 20:43:40 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 20:43:40 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0MKg8l81714
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 15:42:08 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0MKfnf28202;
|
||
Tue, 22 Jan 2002 15:41:49 -0500 (EST)
|
||
To: Fernando Nasser <fnasser@redhat.com>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C4DCBDB.689D7201@redhat.com>
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us> <3C4D8A39.FF79CDC4@redhat.com> <15339.1011716171@sss.pgh.pa.us> <3C4D96C5.80BBF764@redhat.com> <15638.1011718290@sss.pgh.pa.us> <3C4DCBDB.689D7201@redhat.com>
|
||
Comments: In-reply-to Fernando Nasser <fnasser@redhat.com>
|
||
message dated "Tue, 22 Jan 2002 15:30:20 -0500"
|
||
Date: Tue, 22 Jan 2002 15:41:49 -0500
|
||
Message-ID: <28199.1011732109@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Fernando Nasser <fnasser@redhat.com> writes:
|
||
> The only problem in the scenario above is that the standard says that
|
||
> when creating objects and not specifying the schema the schema name
|
||
> should be assumed to be the current user authorization id (or whatever
|
||
> authorization id the code is running as). In our case it would go to
|
||
> the default schema. If someone wants the SQL std behavior then, he/she
|
||
> must create things inside a CREATE SCHEMA statement or explicitly
|
||
> qualify
|
||
> with the schema name the objects being created. Can we live with
|
||
> that?
|
||
|
||
Huh? You seem to be assuming that we need to support both the
|
||
historical Postgres behavior and the SQL-standard behavior with exactly
|
||
the same configuration switches. That's not how I'm seeing it at all.
|
||
The way I'm envisioning it, you could get either the historical
|
||
behavior, or the standard's behavior, depending on how you set up the
|
||
configuration variables. I don't see any particular reason to limit the
|
||
system to just those two cases, either, if the underlying implementation
|
||
has enough flexibility to support custom namespace configurations.
|
||
|
||
I believe that we could get the historical behavior with something like
|
||
|
||
schema search path = ("public" schema, system schema);
|
||
|
||
default creation schema = "public" schema
|
||
|
||
and the standard's behavior with something like
|
||
|
||
schema search path = (user's own schema, system schema);
|
||
|
||
default creation schema = user's own schema
|
||
|
||
(ignoring the issue of a schema for temp tables for the moment).
|
||
|
||
If you prefer to think of these things as "namespaces" rather than
|
||
"schemas", that's fine with me ... what we're talking about here
|
||
is an implementation that can support SQL-style schemas, but isn't
|
||
narrowly able to do only that.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M17985=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 16:15:56 2002
|
||
Return-path: <pgsql-hackers-owner+M17985=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MLFrU10671
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 16:15:53 -0500 (EST)
|
||
Received: (qmail 94223 invoked by alias); 22 Jan 2002 21:14:17 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 21:14:17 -0000
|
||
Received: from cygnus.com (runyon.sfbay.redhat.com [205.180.230.5] (may be forged))
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0ML2fl90295
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 16:02:41 -0500 (EST)
|
||
(envelope-from fnasser@redhat.com)
|
||
Received: from redhat.com (rtl.sfbay.redhat.com [205.180.230.21])
|
||
by runyon.cygnus.com (8.8.7-cygnus/8.8.7) with ESMTP id NAA12269;
|
||
Tue, 22 Jan 2002 13:02:34 -0800 (PST)
|
||
Message-ID: <3C4DD34F.CC4D8B6@redhat.com>
|
||
Date: Tue, 22 Jan 2002 16:02:07 -0500
|
||
From: Fernando Nasser <fnasser@redhat.com>
|
||
Organization: Red Hat Canada
|
||
X-Mailer: Mozilla 4.78 [en] (X11; U; Linux 2.4.9-13 i686)
|
||
X-Accept-Language: en
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us> <3C4D8A39.FF79CDC4@redhat.com> <15339.1011716171@sss.pgh.pa.us> <3C4D96C5.80BBF764@redhat.com> <15638.1011718290@sss.pgh.pa.us> <3C4DCBDB.689D7201@redhat.com> <28199.1011732109@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> Huh? You seem to be assuming that we need to support both the
|
||
> historical Postgres behavior and the SQL-standard behavior with exactly
|
||
> the same configuration switches. That's not how I'm seeing it at all.
|
||
> The way I'm envisioning it, you could get either the historical
|
||
> behavior, or the standard's behavior, depending on how you set up the
|
||
> configuration variables.
|
||
|
||
Then we can live just with the schema being the ownership.
|
||
|
||
Switches set to standard:
|
||
|
||
schema search path = ("user's own schema", postgres)
|
||
|
||
[ default creation schema = user's own schema ] same as below,
|
||
we don't need this
|
||
switch
|
||
|
||
Switches set to historical:
|
||
|
||
schema search path = (user's own schema, "any" schema, postgres)
|
||
|
||
[ default creation schema = user's own schema ]
|
||
|
||
The searching in "any" schema (i.e., any owner) will let will find
|
||
things that where defined the way they are today, i.e., possibly
|
||
by several different users.
|
||
|
||
|
||
P.S.: You can even add the "default" schema in the standard case and
|
||
I believe you are still compliant and can handle things easier:
|
||
schema search path = ("user's own schema", postgres)
|
||
|
||
|
||
Maybe you could give an example of a case where the schema meaning
|
||
ownership breaks things. Or what kind of additional things you have
|
||
in mind that would require orthogonal schema and ownership spaces.
|
||
|
||
|
||
Regards,
|
||
Fernando
|
||
|
||
|
||
|
||
|
||
--
|
||
Fernando Nasser
|
||
Red Hat Canada Ltd. E-Mail: fnasser@redhat.com
|
||
2323 Yonge Street, Suite #300
|
||
Toronto, Ontario M4P 2C9
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M17986=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 16:23:41 2002
|
||
Return-path: <pgsql-hackers-owner+M17986=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MLNbU11596
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 16:23:38 -0500 (EST)
|
||
Received: (qmail 703 invoked by alias); 22 Jan 2002 21:23:31 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 21:23:31 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0MLEYl94662
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 16:14:34 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0MLEGf28560;
|
||
Tue, 22 Jan 2002 16:14:17 -0500 (EST)
|
||
To: Fernando Nasser <fnasser@redhat.com>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C4DD34F.CC4D8B6@redhat.com>
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us> <3C4D8A39.FF79CDC4@redhat.com> <15339.1011716171@sss.pgh.pa.us> <3C4D96C5.80BBF764@redhat.com> <15638.1011718290@sss.pgh.pa.us> <3C4DCBDB.689D7201@redhat.com> <28199.1011732109@sss.pgh.pa.us> <3C4DD34F.CC4D8B6@redhat.com>
|
||
Comments: In-reply-to Fernando Nasser <fnasser@redhat.com>
|
||
message dated "Tue, 22 Jan 2002 16:02:07 -0500"
|
||
Date: Tue, 22 Jan 2002 16:14:16 -0500
|
||
Message-ID: <28557.1011734056@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Fernando Nasser <fnasser@redhat.com> writes:
|
||
> Switches set to historical:
|
||
|
||
> schema search path = (user's own schema, "any" schema, postgres)
|
||
|
||
> [ default creation schema = user's own schema ]
|
||
|
||
> The searching in "any" schema (i.e., any owner) will let will find
|
||
> things that where defined the way they are today, i.e., possibly
|
||
> by several different users.
|
||
|
||
No, it won't, because nothing will ever get put into that schema.
|
||
(At least not by existing pg_dump scripts, which are the things that
|
||
really need to see the historical behavior.) The
|
||
default-creation-schema variable has got to point at any/public/
|
||
whatever-we-call it, or you do not have the historical behavior.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M17988=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 16:44:43 2002
|
||
Return-path: <pgsql-hackers-owner+M17988=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MLifU13572
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 16:44:41 -0500 (EST)
|
||
Received: (qmail 8653 invoked by alias); 22 Jan 2002 21:43:27 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 21:43:27 -0000
|
||
Received: from cygnus.com (runyon.sfbay.redhat.com [205.180.230.5] (may be forged))
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0MLR6l02610
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 16:27:06 -0500 (EST)
|
||
(envelope-from fnasser@redhat.com)
|
||
Received: from redhat.com (rtl.sfbay.redhat.com [205.180.230.21])
|
||
by runyon.cygnus.com (8.8.7-cygnus/8.8.7) with ESMTP id NAA14337;
|
||
Tue, 22 Jan 2002 13:27:00 -0800 (PST)
|
||
Message-ID: <3C4DD909.F26FD0D1@redhat.com>
|
||
Date: Tue, 22 Jan 2002 16:26:33 -0500
|
||
From: Fernando Nasser <fnasser@redhat.com>
|
||
Organization: Red Hat Canada
|
||
X-Mailer: Mozilla 4.78 [en] (X11; U; Linux 2.4.9-13 i686)
|
||
X-Accept-Language: en
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us> <3C4D8A39.FF79CDC4@redhat.com> <15339.1011716171@sss.pgh.pa.us> <3C4D96C5.80BBF764@redhat.com> <15638.1011718290@sss.pgh.pa.us> <3C4DCBDB.689D7201@redhat.com> <28199.1011732109@sss.pgh.pa.us> <3C4DD34F.CC4D8B6@redhat.com> <28557.1011734056@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> Fernando Nasser <fnasser@redhat.com> writes:
|
||
> > Switches set to historical:
|
||
>
|
||
> > schema search path = (user's own schema, "any" schema, postgres)
|
||
>
|
||
> > [ default creation schema = user's own schema ]
|
||
>
|
||
> > The searching in "any" schema (i.e., any owner) will let will find
|
||
> > things that where defined the way they are today, i.e., possibly
|
||
> > by several different users.
|
||
>
|
||
> No, it won't, because nothing will ever get put into that schema.
|
||
> (At least not by existing pg_dump scripts, which are the things that
|
||
> really need to see the historical behavior.) The
|
||
> default-creation-schema variable has got to point at any/public/
|
||
> whatever-we-call it, or you do not have the historical behavior.
|
||
>
|
||
|
||
You did not understand what I meant by "any". It is not a schema
|
||
called "any". It is _any_ schema.
|
||
|
||
Example:
|
||
|
||
A creates a table (do not specify the schema) so it gets into
|
||
the schema named A (as per standard).
|
||
|
||
B refers to the table without qualifying it...
|
||
|
||
In the standard case: look into schema B (=> not found), not in
|
||
postgres either.
|
||
ERROR: Inv. relation As the standard requires.
|
||
|
||
In the historical mode: look into schema B (=> not found), look into
|
||
ANY
|
||
schema (finds it in A). Works as it is today.
|
||
|
||
|
||
Note that I only suggest looking in B first (in the historical case)
|
||
because
|
||
this will allow for the coexistence of the current mode with a
|
||
quasi-compliant
|
||
use of SQL-Schemas. You only need to change the switch if you want
|
||
strict
|
||
compliance.
|
||
|
||
|
||
|
||
--
|
||
Fernando Nasser
|
||
Red Hat Canada Ltd. E-Mail: fnasser@redhat.com
|
||
2323 Yonge Street, Suite #300
|
||
Toronto, Ontario M4P 2C9
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M17987=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 16:45:30 2002
|
||
Return-path: <pgsql-hackers-owner+M17987=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MLjSU13642
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 16:45:29 -0500 (EST)
|
||
Received: (qmail 8533 invoked by alias); 22 Jan 2002 21:43:23 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 21:43:23 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0MLZ5l06911
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 16:35:05 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0MLYlf28790;
|
||
Tue, 22 Jan 2002 16:34:47 -0500 (EST)
|
||
To: Fernando Nasser <fnasser@redhat.com>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C4DD909.F26FD0D1@redhat.com>
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us> <3C4D8A39.FF79CDC4@redhat.com> <15339.1011716171@sss.pgh.pa.us> <3C4D96C5.80BBF764@redhat.com> <15638.1011718290@sss.pgh.pa.us> <3C4DCBDB.689D7201@redhat.com> <28199.1011732109@sss.pgh.pa.us> <3C4DD34F.CC4D8B6@redhat.com> <28557.1011734056@sss.pgh.pa.us> <3C4DD909.F26FD0D1@redhat.com>
|
||
Comments: In-reply-to Fernando Nasser <fnasser@redhat.com>
|
||
message dated "Tue, 22 Jan 2002 16:26:33 -0500"
|
||
Date: Tue, 22 Jan 2002 16:34:47 -0500
|
||
Message-ID: <28787.1011735287@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Fernando Nasser <fnasser@redhat.com> writes:
|
||
> In the historical mode: look into schema B (=> not found), look into
|
||
> ANY schema (finds it in A). Works as it is today.
|
||
|
||
No, it doesn't work the same as today, because in that implementation
|
||
both A and B can create the same tablename without complaint. It then
|
||
becomes very unclear which instance other people will get (unless your
|
||
"any" placeholder somehow implies a search order).
|
||
|
||
The idea of being able to put an "any" placeholder into the search list
|
||
is an interesting one, though. If we can resolve the ambiguity problem
|
||
it might be a useful feature.
|
||
|
||
I am a little troubled by the idea of placing "any" before the system
|
||
schema (what if JRandomLuser creates a table named "pg_class"?) but it
|
||
might be workable at the tail end of the path.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M17991=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 17:13:49 2002
|
||
Return-path: <pgsql-hackers-owner+M17991=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MMDmU19678
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 17:13:49 -0500 (EST)
|
||
Received: (qmail 19170 invoked by alias); 22 Jan 2002 22:13:14 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 22:13:14 -0000
|
||
Received: from cygnus.com (runyon.sfbay.redhat.com [205.180.230.5] (may be forged))
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0MM3ql17554
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 17:03:53 -0500 (EST)
|
||
(envelope-from fnasser@redhat.com)
|
||
Received: from redhat.com (rtl.sfbay.redhat.com [205.180.230.21])
|
||
by runyon.cygnus.com (8.8.7-cygnus/8.8.7) with ESMTP id OAA18084;
|
||
Tue, 22 Jan 2002 14:03:46 -0800 (PST)
|
||
Message-ID: <3C4DE1A7.98860E96@redhat.com>
|
||
Date: Tue, 22 Jan 2002 17:03:19 -0500
|
||
From: Fernando Nasser <fnasser@redhat.com>
|
||
Organization: Red Hat Canada
|
||
X-Mailer: Mozilla 4.78 [en] (X11; U; Linux 2.4.9-13 i686)
|
||
X-Accept-Language: en
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.LNX.4.30.0201211840260.687-100000@peter.localdomain> <12239.1011661590@sss.pgh.pa.us> <3C4D8A39.FF79CDC4@redhat.com> <15339.1011716171@sss.pgh.pa.us> <3C4D96C5.80BBF764@redhat.com> <15638.1011718290@sss.pgh.pa.us> <3C4DCBDB.689D7201@redhat.com> <28199.1011732109@sss.pgh.pa.us> <3C4DD34F.CC4D8B6@redhat.com> <28557.1011734056@sss.pgh.pa.us> <3C4DD909.F26FD0D1@redhat.com> <28787.1011735287@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> Fernando Nasser <fnasser@redhat.com> writes:
|
||
> > In the historical mode: look into schema B (=> not found), look into
|
||
> > ANY schema (finds it in A). Works as it is today.
|
||
>
|
||
> No, it doesn't work the same as today, because in that implementation
|
||
> both A and B can create the same tablename without complaint.
|
||
|
||
I agree that we won't be able to catch this as an error unless we turn
|
||
another switch that requires unique names (there goes one of the
|
||
advantages
|
||
of having schemas, but there is always the option of leaving it on).
|
||
|
||
In this case it would be more close to the current behavior but what is
|
||
left of the SQL-Schemas will be more of a syntactic sugar (although it
|
||
can
|
||
be still used by the DBA to better organize the grant of privileges).
|
||
|
||
Anyway, it would be a DBA option to live with not detecting duplicate
|
||
names. And, I hope all our tools, graphical or not, will make it clear
|
||
what
|
||
is the schema things are defined into, so it would not be difficult to
|
||
figure out what is going wrong if something goes wrong (and we can also
|
||
print the relation oid on messages).
|
||
|
||
> It then
|
||
> becomes very unclear which instance other people will get (unless your
|
||
> "any" placeholder somehow implies a search order).
|
||
>
|
||
|
||
If someone is just using the current mode, there shouldn't be (all names
|
||
are
|
||
database-unique).
|
||
|
||
The only case where this situation can happen is if someone is trying
|
||
to use schemas and the historical non-schema organization in the same
|
||
database, right? Can we make the search order per database?)
|
||
|
||
One possibility is to state that this is not recommended (one should
|
||
organize things as schemas or not at all in a database) and say that
|
||
the search order, besides the current AuthId, is unspecified (random).
|
||
|
||
Another possibility is to allow only one object with that name in the
|
||
"any" space. If someone means an object that was defined on a schema,
|
||
he/she can qualify the name with the schema (good practice). The only
|
||
case where this is not possible is the legacy case, where there is
|
||
exactly one object with that name anyway.
|
||
|
||
I prefer this second solution.
|
||
|
||
> The idea of being able to put an "any" placeholder into the search list
|
||
> is an interesting one, though. If we can resolve the ambiguity problem
|
||
> it might be a useful feature.
|
||
>
|
||
|
||
See above.
|
||
|
||
> I am a little troubled by the idea of placing "any" before the system
|
||
> schema (what if JRandomLuser creates a table named "pg_class"?) but it
|
||
> might be workable at the tail end of the path.
|
||
>
|
||
|
||
Yes, I thought of that as I was typing, but it was not the important
|
||
point at that time. You're right, should go at the end.
|
||
|
||
--
|
||
Fernando Nasser
|
||
Red Hat Canada Ltd. E-Mail: fnasser@redhat.com
|
||
2323 Yonge Street, Suite #300
|
||
Toronto, Ontario M4P 2C9
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 5: Have you checked our extensive FAQ?
|
||
|
||
http://www.postgresql.org/users-lounge/docs/faq.html
|
||
|
||
From pgsql-hackers-owner+M17993=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 18:44:53 2002
|
||
Return-path: <pgsql-hackers-owner+M17993=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MNiqU29215
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 18:44:53 -0500 (EST)
|
||
Received: (qmail 36986 invoked by alias); 22 Jan 2002 23:43:31 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 23:43:31 -0000
|
||
Received: from student.gvsu.edu ([148.61.7.124])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0MNGYl30543
|
||
for <pgsql-hackers@postgreSQL.org>; Tue, 22 Jan 2002 18:16:34 -0500 (EST)
|
||
(envelope-from peter_e@gmx.net)
|
||
Received: from [148.61.250.147] [148.61.250.147] by student.gvsu.edu
|
||
with Novonyx SMTP Server $Revision: 1.3 $; Tue, 22 Jan 2002 18:16:37 -0500 (EDT)
|
||
Date: Tue, 22 Jan 2002 18:18:38 -0500 (EST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
X-Sender: <peter@peter.localdomain>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <12239.1011661590@sss.pgh.pa.us>
|
||
Message-ID: <Pine.LNX.4.30.0201221816130.686-100000@peter.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane writes:
|
||
|
||
> I don't buy that premise. It's true that SQL92 equates ownership of a
|
||
> schema with ownership of the objects therein, but AFAICS we have no hope
|
||
> of being forward-compatible with existing database setups (wherein there
|
||
> can be multiple tables of different ownership all in a single namespace)
|
||
> if we don't allow varying ownership within a schema.
|
||
|
||
We could have a Boolean knob that says "if you don't find the object in
|
||
the default schema, search all other schemas". That should provide all
|
||
the backward compatibility we need. Moreover, I figure if we do it that
|
||
way, the whole schema implementation reduces itself mostly to parser work,
|
||
no complicated system catalog changes, no complex overhaul of the
|
||
privilege system -- at least initially.
|
||
|
||
--
|
||
Peter Eisentraut peter_e@gmx.net
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M17992=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 18:34:48 2002
|
||
Return-path: <pgsql-hackers-owner+M17992=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MNYmU28419
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 18:34:48 -0500 (EST)
|
||
Received: (qmail 32848 invoked by alias); 22 Jan 2002 23:34:10 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 23:34:10 -0000
|
||
Received: from student.gvsu.edu ([148.61.7.124])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0MNPUl31485
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 18:25:30 -0500 (EST)
|
||
(envelope-from peter_e@gmx.net)
|
||
Received: from [148.61.250.147] [148.61.250.147] by student.gvsu.edu
|
||
with Novonyx SMTP Server $Revision: 1.3 $; Tue, 22 Jan 2002 18:25:33 -0500 (EDT)
|
||
Date: Tue, 22 Jan 2002 18:27:35 -0500 (EST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
X-Sender: <peter@peter.localdomain>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Fernando Nasser <fnasser@redhat.com>, <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <28787.1011735287@sss.pgh.pa.us>
|
||
Message-ID: <Pine.LNX.4.30.0201221824360.686-100000@peter.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane writes:
|
||
|
||
> No, it doesn't work the same as today, because in that implementation
|
||
> both A and B can create the same tablename without complaint. It then
|
||
> becomes very unclear which instance other people will get (unless your
|
||
> "any" placeholder somehow implies a search order).
|
||
|
||
The "search any schema" switch is only intended for use with legacy
|
||
databases, where duplicate names don't occur anyway. If someone uses it
|
||
with a new schema-using database design, then he kind of ought to know
|
||
that the switch probably doesn't make a whole lot of sense. However, to
|
||
get reproduceable behaviour anyway we can just define a search order, such
|
||
as by schema name.
|
||
|
||
--
|
||
Peter Eisentraut peter_e@gmx.net
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M17994=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 18:45:53 2002
|
||
Return-path: <pgsql-hackers-owner+M17994=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0MNjqU29324
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 18:45:52 -0500 (EST)
|
||
Received: (qmail 37021 invoked by alias); 22 Jan 2002 23:43:34 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 22 Jan 2002 23:43:34 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0MNVOl31958
|
||
for <pgsql-hackers@postgreSQL.org>; Tue, 22 Jan 2002 18:31:24 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0MNV8f29291;
|
||
Tue, 22 Jan 2002 18:31:08 -0500 (EST)
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
cc: pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.LNX.4.30.0201221816130.686-100000@peter.localdomain>
|
||
References: <Pine.LNX.4.30.0201221816130.686-100000@peter.localdomain>
|
||
Comments: In-reply-to Peter Eisentraut <peter_e@gmx.net>
|
||
message dated "Tue, 22 Jan 2002 18:18:38 -0500"
|
||
Date: Tue, 22 Jan 2002 18:31:08 -0500
|
||
Message-ID: <29288.1011742268@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> Moreover, I figure if we do it that
|
||
> way, the whole schema implementation reduces itself mostly to parser work,
|
||
> no complicated system catalog changes, no complex overhaul of the
|
||
> privilege system -- at least initially.
|
||
|
||
Why are you guys so eager to save me work? I'm not in the least
|
||
interested in implementing a "schema" feature that can only handle
|
||
the entry-level user == schema case. Therefore, just relabeling the
|
||
owner column as schema isn't an interesting option.
|
||
|
||
I really don't see what's wrong with building a namespace mechanism
|
||
that is orthogonal to ownership and then using that to implement what
|
||
SQL92 wants. I think this will be cleaner, simpler, and more flexible
|
||
than trying to equate ownership with namespace.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M17997=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 19:13:42 2002
|
||
Return-path: <pgsql-hackers-owner+M17997=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0N0DgU01512
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 19:13:42 -0500 (EST)
|
||
Received: (qmail 46269 invoked by alias); 23 Jan 2002 00:13:11 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 00:13:11 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0N02bl42634
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 19:02:37 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0N02Kf29439;
|
||
Tue, 22 Jan 2002 19:02:21 -0500 (EST)
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
cc: Fernando Nasser <fnasser@redhat.com>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.LNX.4.30.0201221824360.686-100000@peter.localdomain>
|
||
References: <Pine.LNX.4.30.0201221824360.686-100000@peter.localdomain>
|
||
Comments: In-reply-to Peter Eisentraut <peter_e@gmx.net>
|
||
message dated "Tue, 22 Jan 2002 18:27:35 -0500"
|
||
Date: Tue, 22 Jan 2002 19:02:20 -0500
|
||
Message-ID: <29436.1011744140@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> Tom Lane writes:
|
||
>> No, it doesn't work the same as today, because in that implementation
|
||
>> both A and B can create the same tablename without complaint. It then
|
||
>> becomes very unclear which instance other people will get (unless your
|
||
>> "any" placeholder somehow implies a search order).
|
||
|
||
> The "search any schema" switch is only intended for use with legacy
|
||
> databases, where duplicate names don't occur anyway.
|
||
|
||
That's a mighty narrow view of the world. Do you think that people had
|
||
better convert to SQL schemas before they ever again create a table?
|
||
The fact is that ordinary non-schema-aware usage will certainly lead to
|
||
the above scenario.
|
||
|
||
> that the switch probably doesn't make a whole lot of sense. However, to
|
||
> get reproduceable behaviour anyway we can just define a search order, such
|
||
> as by schema name.
|
||
|
||
Or say that you get an "ambiguous reference" error if there is more than
|
||
one possible candidate in the "any" namespace. (Although that opens the
|
||
door for innocent creation of a table foo by one user to break other
|
||
people's formerly-working queries that reference some other foo.)
|
||
Bottom line for me is that this is an untried concept. I think the
|
||
concept of an "any" searchlist entry is risky enough that I don't much
|
||
want to hang the entire usability of the implementation on the
|
||
assumption that we won't find any fatal problems with "any".
|
||
|
||
|
||
However, the argument over whether SQL92's concept of ownership should
|
||
be taken as gospel is not really the argument I wanted to have in this
|
||
thread. Is it possible to go back to the original point concerning
|
||
whether there should be different namespace boundaries for different
|
||
types of objects? You aren't going to avoid those issues by saying that
|
||
namespace == ownership is good enough.
|
||
|
||
I'm particularly troubled by the idea of trying to apply this "any"
|
||
lookup concept to resolution of overloaded operators and functions.
|
||
Suppose I have a reference func(type1,type2) that I'm trying to resolve,
|
||
and I have an inexact match (one requiring coercion) in my own schema.
|
||
Do I look to the "any" schema to see if there are better matches?
|
||
If so, what happens if the "any" schema contains multiple possibilities
|
||
with identical signatures (presumably created by different users)? ISTM
|
||
this will positively guarantee a resolution failure, since there's no
|
||
way for the resolver to prefer one over another. Thus, by creating
|
||
a "func(foo,bar)" function --- quite legally --- JRandomLuser might
|
||
break other people's formerly working queries that use other functions
|
||
named func. Although it's possible for this to happen now, it'll be
|
||
a lot more surprising if JRandomLuser thinks that his functions live
|
||
in his own private schema namespace.
|
||
|
||
I'm thinking that the overloading concept is not going to play well
|
||
at all with multiple namespaces for functions or operators, and that
|
||
we'd be best off to say that there is only one namespace (per database)
|
||
for these things.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M17998=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 19:33:10 2002
|
||
Return-path: <pgsql-hackers-owner+M17998=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0N0X9U02302
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 19:33:09 -0500 (EST)
|
||
Received: (qmail 52787 invoked by alias); 23 Jan 2002 00:33:08 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 00:33:08 -0000
|
||
Received: from ece.rice.edu (ece.rice.edu [128.42.4.34])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0N0IEl49263
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 19:18:14 -0500 (EST)
|
||
(envelope-from reedstrm@rice.edu)
|
||
Received: from localhost (localhost [127.0.0.1])
|
||
by ece.rice.edu (Postfix) with ESMTP
|
||
id A57FF68A57; Tue, 22 Jan 2002 18:18:14 -0600 (CST)
|
||
Received: from wallace.ece.rice.edu (wallace.ece.rice.edu [128.42.12.154])
|
||
by ece.rice.edu (Postfix) with ESMTP
|
||
id 393F168A1D; Tue, 22 Jan 2002 18:18:13 -0600 (CST)
|
||
Received: from reedstrm by wallace.ece.rice.edu with local (Exim 3.22 #1 (Debian))
|
||
id 16TB7F-000292-00; Tue, 22 Jan 2002 18:18:13 -0600
|
||
Date: Tue, 22 Jan 2002 18:18:13 -0600
|
||
From: "Ross J. Reedstrom" <reedstrm@rice.edu>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Message-ID: <20020123001812.GB7932@rice.edu>
|
||
Mail-Followup-To: "Ross J. Reedstrom" <reedstrm@ece.rice.edu>,
|
||
Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
pgsql-hackers@postgresql.org
|
||
References: <Pine.LNX.4.30.0201221816130.686-100000@peter.localdomain> <29288.1011742268@sss.pgh.pa.us>
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Disposition: inline
|
||
In-Reply-To: <29288.1011742268@sss.pgh.pa.us>
|
||
User-Agent: Mutt/1.3.25i
|
||
X-Virus-Scanned: by AMaViS snapshot-20010714
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Tue, Jan 22, 2002 at 06:31:08PM -0500, Tom Lane wrote:
|
||
> Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> > Moreover, I figure if we do it that
|
||
> > way, the whole schema implementation reduces itself mostly to parser work,
|
||
> > no complicated system catalog changes, no complex overhaul of the
|
||
> > privilege system -- at least initially.
|
||
>
|
||
> Why are you guys so eager to save me work? I'm not in the least
|
||
> interested in implementing a "schema" feature that can only handle
|
||
> the entry-level user == schema case. Therefore, just relabeling the
|
||
> owner column as schema isn't an interesting option.
|
||
>
|
||
> I really don't see what's wrong with building a namespace mechanism
|
||
> that is orthogonal to ownership and then using that to implement what
|
||
> SQL92 wants. I think this will be cleaner, simpler, and more flexible
|
||
> than trying to equate ownership with namespace.
|
||
>
|
||
|
||
I'm with Tom on this: the extended Schema capability he's described
|
||
combines the best of both authentication mechanisms, IMHO. It give
|
||
us namespace separation ala the SQL standard, and individual object
|
||
ownership, like unix FS semantics. Only having ownership on the
|
||
'containers' strikes me as limiting, even if that is how the standard
|
||
describes it.
|
||
|
||
Ross
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18002=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 20:33:04 2002
|
||
Return-path: <pgsql-hackers-owner+M18002=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0N1X3U05117
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 20:33:03 -0500 (EST)
|
||
Received: (qmail 73320 invoked by alias); 23 Jan 2002 01:32:55 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 01:32:55 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0N1FDl69103
|
||
for <pgsql-hackers@postgreSQL.org>; Tue, 22 Jan 2002 20:15:14 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 12961 invoked by uid 1130); 23 Jan 2002 01:15:07 -0000
|
||
Date: Tue, 22 Jan 2002 17:10:24 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <11381.1011648592@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201221657270.5119-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Mon, 21 Jan 2002, Tom Lane wrote:
|
||
|
||
> Continuing to think about implementing SQL schemas for 7.3 ...
|
||
>
|
||
> Today's topic for discussion: which types of Postgres objects should
|
||
> belong to schemas, and which ones should have other name scopes?
|
||
>
|
||
> Relations (tables, indexes, views, sequences) clearly belong to schemas.
|
||
> Since each relation has an associated datatype with the same name, it
|
||
> seems that datatypes must belong to schemas as well. (Even if that
|
||
> argument doesn't convince you, SQL99 says that user-defined datatypes
|
||
> belong to schemas.) However the situation is murkier for other kinds of
|
||
> objects.
|
||
>
|
||
> Here are all the kinds of named objects that exist in Postgres today,
|
||
> with some comments on whether they should belong to schemas or not:
|
||
>
|
||
> relations Must be in schemas
|
||
> types Must be in schemas
|
||
> databases Databases contain schemas, not vice versa
|
||
> users Users are cross-database, so not in schemas
|
||
> groups User groups are cross-database, so not in schemas
|
||
> languages Probably should not be in schemas
|
||
> access methods Probably should not be in schemas
|
||
> opclasses See below
|
||
> operators See below
|
||
> functions/procedures See below
|
||
> aggregates Should treat same as regular functions
|
||
> constraints See below
|
||
> rules See below
|
||
> triggers See below
|
||
> NOTIFY conditions See below
|
||
>
|
||
> Languages and access methods are not trivial to add to the system, so
|
||
> there's not much risk of name conflicts, and no reason to make their name
|
||
> scope less than global.
|
||
>
|
||
> The situation is a lot murkier for operators and functions. These should
|
||
> probably be treated alike, since operators are just syntactic sugar for
|
||
> functions. I think the basic argument for making them schema-local is
|
||
> that different users might conceivably want to define conflicting
|
||
> functions or operators of the same name. Against that, however, there
|
||
> are a number of reasons for wanting to keep these objects database-wide.
|
||
> First off there are syntactic problems. Do you really want to write
|
||
> A schemaname.+ B
|
||
> to qualify an ambiguous "+" operator? Looks way too much like a syntax
|
||
> error to me. Allowing this would probably turn a lot of simple syntax
|
||
> errors into things that get past the grammar and end up producing truly
|
||
> confusing error messages. Qualified function names also pose some
|
||
> problems, not so much with
|
||
> schemaname.function(args)
|
||
> which seems reasonable, but with the Berkeley-derived syntax that allows
|
||
> "foo.function" to mean "function(foo)" --- there's no way to squeeze a
|
||
> schema-name for the function into that. (And you'll recall from my note
|
||
|
||
Why not? What's wrong with either schema.foo.function (==>
|
||
function(schema.foo)) or foo.schema.function (==> schema.function(foo))?
|
||
Tables and functions can't have the same names as schemas, so we will be
|
||
able to notice the schema names in there. Oh, and I worked out how to get
|
||
parse.y to be happy with x.y & x.y.z (schema.package.function) names. :-)
|
||
|
||
> of the other day that we don't want to abandon this syntax entirely,
|
||
> because people would like us to support "sequencename.nextval" for Oracle
|
||
> compatibility.) Notice that we are not forced to make functions/operators
|
||
> schema-local just because datatypes are, because overloading will save the
|
||
> day. func(schema1.type1) and func(schema2.type1) are distinct functions
|
||
> because the types are different, even if they live in the same function
|
||
> namespace. Finally, SQL99 doesn't appear to think that operator and
|
||
> function names are schema-local; though that may just be because it hasn't
|
||
> got user-defined operators AFAICT.
|
||
|
||
Actually functions do have to be schema local. It's in the spec (don't
|
||
have exactly where with me).
|
||
|
||
> I am leaning towards keeping functions/operators database-wide, but would
|
||
> like to hear comments. Is there any real value in, eg, allowing different
|
||
> users to define different "+" operators *on the same datatypes*?
|
||
|
||
Yes. It means that third-party developers can develop routines and then
|
||
operators based on them without having to worry about conflicts. Obviously
|
||
these two different operators would have to be in different schemas. Also,
|
||
it would mean that someone could ship replacement operators for built-in
|
||
operators. Say adding a + operator which throws exceptions on overflow.
|
||
:-)
|
||
|
||
> Not sure about index opclasses. Given that datatype names are
|
||
> schema-local, one can think of scenarios where two users define similar
|
||
> datatypes and then try to use the same index opclass name for both.
|
||
> But it seems pretty unlikely. I'd prefer to leave opclass names
|
||
> database-wide for simplicity. Comments?
|
||
|
||
My vote would be to make them schema-specific. As Peter pointed out,
|
||
schemas are how you own things, so put them in a schema so we can keep
|
||
track of ownership.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18001=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 20:23:11 2002
|
||
Return-path: <pgsql-hackers-owner+M18001=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0N1NAU04735
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 20:23:10 -0500 (EST)
|
||
Received: (qmail 70414 invoked by alias); 23 Jan 2002 01:23:01 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 01:23:01 -0000
|
||
Received: from corvette.mascari.com (dhcp065-024-158-068.columbus.rr.com [65.24.158.68])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0N1KBl69469
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 20:20:11 -0500 (EST)
|
||
(envelope-from mascarm@mascari.com)
|
||
Received: from mascari.com (ferrari.mascari.com [192.168.2.1])
|
||
by corvette.mascari.com (8.9.3/8.9.3) with ESMTP id UAA30752
|
||
for <pgsql-hackers@postgresql.org>; Tue, 22 Jan 2002 20:15:29 -0500
|
||
Message-ID: <3C4E0EB1.1E3687FD@mascari.com>
|
||
Date: Tue, 22 Jan 2002 20:15:29 -0500
|
||
From: Mike Mascari <mascarm@mascari.com>
|
||
X-Mailer: Mozilla 4.7 [en] (WinNT; I)
|
||
X-Accept-Language: en
|
||
MIME-Version: 1.0
|
||
To: pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.LNX.4.30.0201221824360.686-100000@peter.localdomain> <29436.1011744140@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> I'm particularly troubled by the idea of trying to apply this "any"
|
||
> lookup concept to resolution of overloaded operators and functions.
|
||
> Suppose I have a reference func(type1,type2) that I'm trying to resolve,
|
||
> and I have an inexact match (one requiring coercion) in my own schema.
|
||
> Do I look to the "any" schema to see if there are better matches?
|
||
> If so, what happens if the "any" schema contains multiple possibilities
|
||
> with identical signatures (presumably created by different users)? ISTM
|
||
> this will positively guarantee a resolution failure, since there's no
|
||
> way for the resolver to prefer one over another. Thus, by creating
|
||
> a "func(foo,bar)" function --- quite legally --- JRandomLuser might
|
||
> break other people's formerly working queries that use other functions
|
||
> named func. Although it's possible for this to happen now, it'll be
|
||
> a lot more surprising if JRandomLuser thinks that his functions live
|
||
> in his own private schema namespace.
|
||
>
|
||
|
||
So, in a nutshell, the price we pay for function overloading is the
|
||
inability to have schema-specific functions. Right? Possibly why Oracle
|
||
doesn't allow function overloading? As a user, I'd much rather have
|
||
schema-specific functions than only global. I'm not downplaying the
|
||
value of function overloading, but if I had the choice (which I guess I
|
||
can't/won't), I'd choose schema-specific functions over function
|
||
overloading...
|
||
|
||
Mike Mascari
|
||
mascarm@mascari.com
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18003=candle.pha.pa.us=pgman@postgresql.org Tue Jan 22 20:52:52 2002
|
||
Return-path: <pgsql-hackers-owner+M18003=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0N1qqU05847
|
||
for <pgman@candle.pha.pa.us>; Tue, 22 Jan 2002 20:52:52 -0500 (EST)
|
||
Received: (qmail 76088 invoked by alias); 23 Jan 2002 01:52:50 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 01:52:50 -0000
|
||
Received: from student.gvsu.edu ([148.61.7.124])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0N1o8l75594
|
||
for <pgsql-hackers@postgreSQL.org>; Tue, 22 Jan 2002 20:50:08 -0500 (EST)
|
||
(envelope-from peter_e@gmx.net)
|
||
Received: from [148.61.250.147] [148.61.250.147] by student.gvsu.edu
|
||
with Novonyx SMTP Server $Revision: 1.3 $; Tue, 22 Jan 2002 20:50:13 -0500 (EDT)
|
||
Date: Tue, 22 Jan 2002 20:52:14 -0500 (EST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
X-Sender: <peter@peter.localdomain>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <29288.1011742268@sss.pgh.pa.us>
|
||
Message-ID: <Pine.LNX.4.30.0201222042400.686-100000@peter.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane writes:
|
||
|
||
> I really don't see what's wrong with building a namespace mechanism
|
||
> that is orthogonal to ownership and then using that to implement what
|
||
> SQL92 wants. I think this will be cleaner, simpler, and more flexible
|
||
> than trying to equate ownership with namespace.
|
||
|
||
OK, I can accept that. But then I want to get back at my original point,
|
||
namely that all database objects (except users and groups) should be in
|
||
schemas. This is also cleaner, simpler, and more flexible. There is
|
||
clearly demand for schema-local functions. So I think that designing this
|
||
system from the premise that a schema-qualified operator call will look
|
||
strange is the wrong end to start at.
|
||
|
||
--
|
||
Peter Eisentraut peter_e@gmx.net
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18006=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 00:13:21 2002
|
||
Return-path: <pgsql-hackers-owner+M18006=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0N5DLU26660
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 00:13:21 -0500 (EST)
|
||
Received: (qmail 12536 invoked by alias); 23 Jan 2002 05:13:01 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 05:13:01 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0N58Cl11241
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 00:08:12 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0N57vf00651;
|
||
Wed, 23 Jan 2002 00:07:58 -0500 (EST)
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201221657270.5119-100000@vespasia.home-net.internetconnect.net>
|
||
References: <Pine.NEB.4.33.0201221657270.5119-100000@vespasia.home-net.internetconnect.net>
|
||
Comments: In-reply-to Bill Studenmund <wrstuden@netbsd.org>
|
||
message dated "Tue, 22 Jan 2002 17:10:24 -0800"
|
||
Date: Wed, 23 Jan 2002 00:07:57 -0500
|
||
Message-ID: <648.1011762477@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> Why not? What's wrong with either schema.foo.function (==>
|
||
> function(schema.foo)) or foo.schema.function (==> schema.function(foo))?
|
||
|
||
Neither is wrong in isolation, but how do you tell the difference?
|
||
More to the point, given input x.y.z, how do you tell which component
|
||
is what?
|
||
|
||
> Tables and functions can't have the same names as schemas,
|
||
|
||
News to me. Where is that written on stone tablets? Even if that's
|
||
considered an acceptable limitation from a purely functional point of
|
||
view, I don't like using it to disambiguate input. The error messages
|
||
you'll get from incorrect input to an implementation that depends on
|
||
that to disambiguate cases will not be very helpful.
|
||
|
||
> Actually functions do have to be schema local. It's in the spec (don't
|
||
> have exactly where with me).
|
||
|
||
(A) I don't believe that; please cite chapter and verse; (B) even if
|
||
SQL92 thinks that's okay, we can't do it that way because of
|
||
backwards-compatibility issues.
|
||
|
||
> My vote would be to make them schema-specific. As Peter pointed out,
|
||
> schemas are how you own things,
|
||
|
||
Sorry, but this line of argument is trying to assume the very point in
|
||
dispute.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18007=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 01:12:58 2002
|
||
Return-path: <pgsql-hackers-owner+M18007=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0N6CvU01868
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 01:12:57 -0500 (EST)
|
||
Received: (qmail 21084 invoked by alias); 23 Jan 2002 06:13:00 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 06:13:00 -0000
|
||
Received: from student.gvsu.edu ([148.61.7.124])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0N69Kl20384
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 01:09:20 -0500 (EST)
|
||
(envelope-from peter_e@gmx.net)
|
||
Received: from [148.61.250.147] [148.61.250.147] by student.gvsu.edu
|
||
with Novonyx SMTP Server $Revision: 1.3 $; Wed, 23 Jan 2002 01:09:18 -0500 (EDT)
|
||
Date: Wed, 23 Jan 2002 01:11:21 -0500 (EST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
X-Sender: <peter@peter.localdomain>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <648.1011762477@sss.pgh.pa.us>
|
||
Message-ID: <Pine.LNX.4.30.0201230058150.686-100000@peter.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane writes:
|
||
|
||
> > Actually functions do have to be schema local. It's in the spec (don't
|
||
> > have exactly where with me).
|
||
>
|
||
> (A) I don't believe that; please cite chapter and verse;
|
||
|
||
In SQL99, chapter 4 verse 23 it says
|
||
|
||
"An SQL-invoked routine is an element of an SQL-schema and is called a
|
||
schema-level routine."
|
||
|
||
> (B) even if
|
||
> SQL92 thinks that's okay, we can't do it that way because of
|
||
> backwards-compatibility issues.
|
||
|
||
I don't buy that. If all you're looking for is preserving
|
||
|
||
foo.bar <==> bar(foo)
|
||
|
||
for compatibility, then you can simply say that "bar" cannot be
|
||
schema-qualified in the left form (so it needs to live in the current or
|
||
the default schema). We currently only have one default schema, so that's
|
||
backward compatible. I think this syntax is a mistake, so I don't feel
|
||
compelled to provide more than backwards compatibility.
|
||
|
||
--
|
||
Peter Eisentraut peter_e@gmx.net
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M18008=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 04:13:30 2002
|
||
Return-path: <pgsql-hackers-owner+M18008=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0N9DTU17316
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 04:13:29 -0500 (EST)
|
||
Received: (qmail 56495 invoked by alias); 23 Jan 2002 09:13:26 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 09:13:26 -0000
|
||
Received: from smxsat1.smxs.net (smxsat1.smxs.net [213.150.10.1])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0N9BKl55718
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 04:11:21 -0500 (EST)
|
||
(envelope-from ZeugswetterA@spardat.at)
|
||
Received: from m01x1.s-mxs.net [10.3.55.201]
|
||
by smxsat1.smxs.net
|
||
with XWall v3.18f ;
|
||
Wed, 23 Jan 2002 10:12:42 +0100
|
||
Received: from m0102.s-mxs.net [10.3.55.2]
|
||
by m01x1.s-mxs.net
|
||
with XWall v3.18a ;
|
||
Wed, 23 Jan 2002 10:11:14 +0100
|
||
Received: from m0114.s-mxs.net ([10.3.55.14]) by m0102.s-mxs.net with Microsoft SMTPSVC(5.0.2195.2966);
|
||
Wed, 23 Jan 2002 10:11:13 +0100
|
||
X-MimeOLE: Produced By Microsoft Exchange V6.0.5762.3
|
||
content-class: urn:content-classes:message
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Date: Wed, 23 Jan 2002 10:11:13 +0100
|
||
Message-ID: <46C15C39FEB2C44BA555E356FBCD6FA41EB4C2@m0114.s-mxs.net>
|
||
Thread-Topic: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Thread-Index: AcGjixqphLJq/YpTSK6U7FZuNf4j3AAWxJvQ
|
||
From: "Zeugswetter Andreas SB SD" <ZeugswetterA@spardat.at>
|
||
To: "Tom Lane" <tgl@sss.pgh.pa.us>, "Fernando Nasser" <fnasser@redhat.com>
|
||
cc: "Peter Eisentraut" <peter_e@gmx.net>, <pgsql-hackers@postgresql.org>
|
||
X-OriginalArrivalTime: 23 Jan 2002 09:11:13.0579 (UTC) FILETIME=[E7DEA7B0:01C1A3ED]
|
||
Content-Transfer-Encoding: 8bit
|
||
X-MIME-Autoconverted: from quoted-printable to 8bit by postgresql.org id g0N9CTm55809
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
|
||
> > Switches set to historical:
|
||
>
|
||
> > schema search path = (user's own schema, "any" schema, postgres)
|
||
>
|
||
> > [ default creation schema = user's own schema ]
|
||
>
|
||
> > The searching in "any" schema (i.e., any owner) will let will find
|
||
> > things that where defined the way they are today, i.e., possibly
|
||
> > by several different users.
|
||
>
|
||
> No, it won't, because nothing will ever get put into that schema.
|
||
> (At least not by existing pg_dump scripts, which are the things that
|
||
> really need to see the historical behavior.) The
|
||
> default-creation-schema variable has got to point at any/public/
|
||
> whatever-we-call it, or you do not have the historical behavior.
|
||
|
||
When configured for historical behavior would need to:
|
||
1. have search path: temp, any, system
|
||
2. guard against duplicate table names across all schemas (except temp schema)
|
||
|
||
Or are you thinking about a per session behavior ?
|
||
I would rather envision a per database behavior.
|
||
|
||
Maybe the easy way out would be a "default creation schema" property for
|
||
each user, that would default to the username. If you want everything in one
|
||
schema simply alter the users.
|
||
|
||
Andreas
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 5: Have you checked our extensive FAQ?
|
||
|
||
http://www.postgresql.org/users-lounge/docs/faq.html
|
||
|
||
From pgsql-hackers-owner+M18010=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 05:03:10 2002
|
||
Return-path: <pgsql-hackers-owner+M18010=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NA39U22271
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 05:03:09 -0500 (EST)
|
||
Received: (qmail 70600 invoked by alias); 23 Jan 2002 10:03:04 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 10:03:04 -0000
|
||
Received: from smxsat1.smxs.net (smxsat1.smxs.net [213.150.10.1])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0N9xNl69597
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 04:59:24 -0500 (EST)
|
||
(envelope-from ZeugswetterA@spardat.at)
|
||
Received: from m01x1.s-mxs.net [10.3.55.201]
|
||
by smxsat1.smxs.net
|
||
with XWall v3.18f ;
|
||
Wed, 23 Jan 2002 11:00:47 +0100
|
||
Received: from m0103.s-mxs.net [10.3.55.3]
|
||
by m01x1.s-mxs.net
|
||
with XWall v3.18a ;
|
||
Wed, 23 Jan 2002 10:59:19 +0100
|
||
Received: from m0114.s-mxs.net ([10.3.55.14]) by m0103.s-mxs.net with Microsoft SMTPSVC(5.0.2195.2966);
|
||
Wed, 23 Jan 2002 10:59:18 +0100
|
||
X-MimeOLE: Produced By Microsoft Exchange V6.0.5762.3
|
||
content-class: urn:content-classes:message
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Date: Wed, 23 Jan 2002 10:59:18 +0100
|
||
Message-ID: <46C15C39FEB2C44BA555E356FBCD6FA42128DA@m0114.s-mxs.net>
|
||
Thread-Topic: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Thread-Index: AcGj1QtRzBpAfJVfQjCydtlooB5fgwAHyaDQ
|
||
From: "Zeugswetter Andreas SB SD" <ZeugswetterA@spardat.at>
|
||
To: "Peter Eisentraut" <peter_e@gmx.net>, "Tom Lane" <tgl@sss.pgh.pa.us>
|
||
cc: "Bill Studenmund" <wrstuden@netbsd.org>, <pgsql-hackers@postgresql.org>
|
||
X-OriginalArrivalTime: 23 Jan 2002 09:59:18.0969 (UTC) FILETIME=[9FB23A90:01C1A3F4]
|
||
Content-Transfer-Encoding: 8bit
|
||
X-MIME-Autoconverted: from quoted-printable to 8bit by postgresql.org id g0NA2d170062
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
|
||
> I don't buy that. If all you're looking for is preserving
|
||
>
|
||
> foo.bar <==> bar(foo)
|
||
>
|
||
> for compatibility, then you can simply say that "bar" cannot be
|
||
> schema-qualified in the left form (so it needs to live in the current or
|
||
> the default schema). We currently only have one default schema, so that's
|
||
> backward compatible. I think this syntax is a mistake, so I don't feel
|
||
> compelled to provide more than backwards compatibility.
|
||
|
||
This syntax is actually my favorite :-) I use it heavily for calculated
|
||
columns. I don't feel it is a mistake.
|
||
|
||
Andreas
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18012=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 06:13:40 2002
|
||
Return-path: <pgsql-hackers-owner+M18012=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NBDdU21327
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 06:13:39 -0500 (EST)
|
||
Received: (qmail 81930 invoked by alias); 23 Jan 2002 11:13:12 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 11:13:12 -0000
|
||
Received: from mail_exchange.westcountrypublications.co.uk ([195.171.163.135])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NB70l80597
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 06:07:02 -0500 (EST)
|
||
(envelope-from SHenshall@westcountrypublications.co.uk)
|
||
Received: by MAIL_EXCHANGE with Internet Mail Service (5.5.2650.21)
|
||
id <DKQFH0AY>; Wed, 23 Jan 2002 11:03:18 -0000
|
||
Message-ID: <E2870D8CE1CCD311BAF50008C71EDE8E01F747A1@MAIL_EXCHANGE>
|
||
From: "Henshall, Stuart - WCP" <SHenshall@westcountrypublications.co.uk>
|
||
To: "'Tom Lane'" <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>
|
||
cc: Fernando Nasser <fnasser@redhat.com>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Date: Wed, 23 Jan 2002 11:03:16 -0000
|
||
MIME-Version: 1.0
|
||
X-Mailer: Internet Mail Service (5.5.2650.21)
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
|
||
|
||
> -----Original Message-----
|
||
> From: Tom Lane [mailto:tgl@sss.pgh.pa.us]
|
||
> Sent: 23 January 2002 00:02
|
||
> To: Peter Eisentraut
|
||
> Cc: Fernando Nasser; pgsql-hackers@postgresql.org
|
||
> Subject: Re: RFD: schemas and different kinds of Postgres objects
|
||
>
|
||
>
|
||
> Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> > Tom Lane writes:
|
||
> >> No, it doesn't work the same as today, because in that
|
||
> implementation
|
||
> >> both A and B can create the same tablename without
|
||
> complaint. It then
|
||
> >> becomes very unclear which instance other people will get
|
||
> (unless your
|
||
> >> "any" placeholder somehow implies a search order).
|
||
>
|
||
> > The "search any schema" switch is only intended for use with legacy
|
||
> > databases, where duplicate names don't occur anyway.
|
||
>
|
||
> That's a mighty narrow view of the world. Do you think that
|
||
> people had
|
||
> better convert to SQL schemas before they ever again create a table?
|
||
> The fact is that ordinary non-schema-aware usage will
|
||
> certainly lead to
|
||
> the above scenario.
|
||
>
|
||
> > that the switch probably doesn't make a whole lot of sense.
|
||
> However, to
|
||
> > get reproduceable behaviour anyway we can just define a
|
||
> search order, such
|
||
> > as by schema name.
|
||
>
|
||
> Or say that you get an "ambiguous reference" error if there
|
||
> is more than
|
||
> one possible candidate in the "any" namespace. (Although
|
||
> that opens the
|
||
> door for innocent creation of a table foo by one user to break other
|
||
> people's formerly-working queries that reference some other foo.)
|
||
> Bottom line for me is that this is an untried concept. I think the
|
||
> concept of an "any" searchlist entry is risky enough that I don't much
|
||
> want to hang the entire usability of the implementation on the
|
||
> assumption that we won't find any fatal problems with "any".
|
||
>
|
||
>
|
||
> However, the argument over whether SQL92's concept of ownership should
|
||
> be taken as gospel is not really the argument I wanted to have in this
|
||
> thread. Is it possible to go back to the original point concerning
|
||
> whether there should be different namespace boundaries for different
|
||
> types of objects? You aren't going to avoid those issues by
|
||
> saying that
|
||
> namespace == ownership is good enough.
|
||
>
|
||
> I'm particularly troubled by the idea of trying to apply this "any"
|
||
> lookup concept to resolution of overloaded operators and functions.
|
||
> Suppose I have a reference func(type1,type2) that I'm trying
|
||
> to resolve,
|
||
> and I have an inexact match (one requiring coercion) in my own schema.
|
||
> Do I look to the "any" schema to see if there are better matches?
|
||
> If so, what happens if the "any" schema contains multiple
|
||
> possibilities
|
||
> with identical signatures (presumably created by different
|
||
> users)? ISTM
|
||
> this will positively guarantee a resolution failure, since there's no
|
||
> way for the resolver to prefer one over another. Thus, by creating
|
||
> a "func(foo,bar)" function --- quite legally --- JRandomLuser might
|
||
> break other people's formerly working queries that use other functions
|
||
> named func. Although it's possible for this to happen now, it'll be
|
||
> a lot more surprising if JRandomLuser thinks that his functions live
|
||
> in his own private schema namespace.
|
||
>
|
||
> I'm thinking that the overloading concept is not going to play well
|
||
> at all with multiple namespaces for functions or operators, and that
|
||
> we'd be best off to say that there is only one namespace (per
|
||
> database)
|
||
> for these things.
|
||
>
|
||
> regards, tom lane
|
||
>
|
||
Could you just have a general rule of search in order of age (by OID)? This
|
||
should prevent changes to existing operation when new definitions come along
|
||
(unless new definition is in new own schema or default).
|
||
Cheers,
|
||
- Stuart
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18024=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 10:13:55 2002
|
||
Return-path: <pgsql-hackers-owner+M18024=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NFDsU06028
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 10:13:54 -0500 (EST)
|
||
Received: (qmail 39657 invoked by alias); 23 Jan 2002 15:13:28 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 15:13:28 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NF1dl35283
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 10:01:40 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0NExef02480;
|
||
Wed, 23 Jan 2002 09:59:40 -0500 (EST)
|
||
To: "Henshall, Stuart - WCP" <SHenshall@westcountrypublications.co.uk>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, Fernando Nasser <fnasser@redhat.com>,
|
||
pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <E2870D8CE1CCD311BAF50008C71EDE8E01F747A1@MAIL_EXCHANGE>
|
||
References: <E2870D8CE1CCD311BAF50008C71EDE8E01F747A1@MAIL_EXCHANGE>
|
||
Comments: In-reply-to "Henshall, Stuart - WCP" <SHenshall@westcountrypublications.co.uk>
|
||
message dated "Wed, 23 Jan 2002 11:03:16 +0000"
|
||
Date: Wed, 23 Jan 2002 09:59:39 -0500
|
||
Message-ID: <2477.1011797979@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
"Henshall, Stuart - WCP" <SHenshall@westcountrypublications.co.uk> writes:
|
||
> Could you just have a general rule of search in order of age (by OID)?
|
||
|
||
No, unless you plan to abandon the whole notion of resolving ambiguous
|
||
operator/function calls. (Which'd cut down our TODO list a good bit ;-)
|
||
but I don't think users would be happy...) OID/age ordering generally
|
||
has little to do with reasonable resolution behavior.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M18026=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 10:33:35 2002
|
||
Return-path: <pgsql-hackers-owner+M18026=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NFXYU07736
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 10:33:34 -0500 (EST)
|
||
Received: (qmail 44416 invoked by alias); 23 Jan 2002 15:33:29 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 15:33:29 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NFVfl43926
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 10:31:41 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0NFVQf02603;
|
||
Wed, 23 Jan 2002 10:31:26 -0500 (EST)
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
cc: pgsql-hackers@postgresql.org, Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.LNX.4.30.0201222042400.686-100000@peter.localdomain>
|
||
References: <Pine.LNX.4.30.0201222042400.686-100000@peter.localdomain>
|
||
Comments: In-reply-to Peter Eisentraut <peter_e@gmx.net>
|
||
message dated "Tue, 22 Jan 2002 20:52:14 -0500"
|
||
Date: Wed, 23 Jan 2002 10:31:25 -0500
|
||
Message-ID: <2600.1011799885@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> OK, I can accept that. But then I want to get back at my original point,
|
||
> namely that all database objects (except users and groups) should be in
|
||
> schemas. This is also cleaner, simpler, and more flexible. There is
|
||
> clearly demand for schema-local functions. So I think that designing this
|
||
> system from the premise that a schema-qualified operator call will look
|
||
> strange is the wrong end to start at.
|
||
|
||
Okay, a fair point --- or you could have used my own argument against
|
||
me: there's nothing wrong with designing a general mechanism and then
|
||
choosing not to expose all of the functionality. So let's assume that
|
||
functions and operators live in namespaces, and that we have some kind
|
||
of search path across multiple namespaces for use when an unqualified
|
||
name is given.
|
||
|
||
Now, how is that going to play with resolution of ambiguous calls?
|
||
|
||
The most reasonable semantics I can think of are to collect all the
|
||
potential matches (matching op/func name) across all the searchable
|
||
namespaces, discarding only those that have exactly the same signature
|
||
as one in a prior namespace. Thus, eg, plus(int4,int4) in an earlier
|
||
namespace would hide plus(int4,int4) in a later namespace in the search
|
||
path, but it wouldn't hide plus(int8,int8). After we've collected all
|
||
the visible alternatives, do resolution based on argument types the same
|
||
way as we do now.
|
||
|
||
The only alternative semantics that seem defensible at all are to stop
|
||
at the first namespace that contains any matching-by-name op or func,
|
||
and do resolution using only the candidates available in that namespace.
|
||
That strikes me as not a good idea; for example, a user who defines a
|
||
"+" operator in his own schema for his own datatype would be quite
|
||
unhappy to find it masking all the "+" operators in the system schema.
|
||
|
||
I believe that this behavior would be fairly reasonable if our
|
||
backward-compatibility feature consists of a "public" namespace
|
||
that all users can write in. OTOH I think it would not play at all
|
||
well if we use Fernando's idea of an "any" wildcard in the search
|
||
path. (1) Imagine the case where we have some users who are using
|
||
the backward-compatible behavior while others have set up private
|
||
namespaces. If Joe SmartGuy creates a "+" operator in his private
|
||
namespace, it'll be visible to people using the "any" wildcard and
|
||
possibly cause resolution-ambiguity failures for them, even though
|
||
Joe deliberately did what he should do to avoid that. (2) "any"
|
||
creates the problem of resolving multiple functions with identical
|
||
signatures in different namespaces, with no reasonable rule for
|
||
making the choice.
|
||
|
||
So I'm still of the opinion that an "any" wildcard is too risky a
|
||
solution for our backwards-compatibility problem.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18030=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 11:35:41 2002
|
||
Return-path: <pgsql-hackers-owner+M18030=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NGZeU13512
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 11:35:40 -0500 (EST)
|
||
Received: (qmail 91981 invoked by alias); 23 Jan 2002 16:34:06 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 16:34:06 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NFjNl67457
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 10:45:58 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0NFiYf02680;
|
||
Wed, 23 Jan 2002 10:44:34 -0500 (EST)
|
||
To: "Zeugswetter Andreas SB SD" <ZeugswetterA@spardat.at>
|
||
cc: "Fernando Nasser" <fnasser@redhat.com>,
|
||
"Peter Eisentraut" <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <46C15C39FEB2C44BA555E356FBCD6FA41EB4C2@m0114.s-mxs.net>
|
||
References: <46C15C39FEB2C44BA555E356FBCD6FA41EB4C2@m0114.s-mxs.net>
|
||
Comments: In-reply-to "Zeugswetter Andreas SB SD" <ZeugswetterA@spardat.at>
|
||
message dated "Wed, 23 Jan 2002 10:11:13 +0100"
|
||
Date: Wed, 23 Jan 2002 10:44:34 -0500
|
||
Message-ID: <2677.1011800674@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: ORr
|
||
|
||
"Zeugswetter Andreas SB SD" <ZeugswetterA@spardat.at> writes:
|
||
> When configured for historical behavior would need to:
|
||
> 1. have search path: temp, any, system
|
||
> 2. guard against duplicate table names across all schemas (except temp schema)
|
||
|
||
This would be a *whole* lot simpler if we forgot the notion of "any"
|
||
and made the search order look like
|
||
|
||
(temp, private, public, system)
|
||
|
||
where the public namespace is world-writable but the private per-user
|
||
ones are (typically at least) not.
|
||
|
||
It occurs to me that we can get both backward-compatible and SQL92
|
||
semantics with this same search path; the only thing that needs to
|
||
be different in the two cases is whether the default place to create
|
||
objects is your private schema or the public one. If you don't ever
|
||
use your private schema then it doesn't matter if it's on the search
|
||
path or not. I would still prefer that the search path be a settable
|
||
option, since a paranoid person might well wish to not have public in
|
||
his path at all ... but the default could be as-above.
|
||
|
||
> Or are you thinking about a per session behavior ?
|
||
> I would rather envision a per database behavior.
|
||
> Maybe the easy way out would be a "default creation schema" property for
|
||
> each user, that would default to the username. If you want everything in one
|
||
> schema simply alter the users.
|
||
|
||
I hadn't really gotten to the point of thinking about exactly what and
|
||
where the control knobs should be. I suspect you are right that we will
|
||
want the default behavior to be selectable on a per-user or per-database
|
||
basis, which seems to eliminate the option of using GUC (at least in its
|
||
current form). We could easily add a field to pg_shadow or pg_database
|
||
respectively to determine the default behavior. It'd be nice though if
|
||
the behavior could be changed after connection by a SET statement, which
|
||
would be lots easier if the setting were GUC-controlled. Peter, you see
|
||
any way to resolve that?
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M18034=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 11:50:22 2002
|
||
Return-path: <pgsql-hackers-owner+M18034=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NGoLU15032
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 11:50:21 -0500 (EST)
|
||
Received: (qmail 1716 invoked by alias); 23 Jan 2002 16:50:05 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 16:50:05 -0000
|
||
Received: from megazone.bigpanda.com (megazone.bigpanda.com [63.150.15.178])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NGZgl93351
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 11:35:42 -0500 (EST)
|
||
(envelope-from sszabo@megazone23.bigpanda.com)
|
||
Received: by megazone.bigpanda.com (Postfix, from userid 1001)
|
||
id ABA27D5E5; Wed, 23 Jan 2002 08:35:47 -0800 (PST)
|
||
Received: from localhost (localhost [127.0.0.1])
|
||
by megazone.bigpanda.com (Postfix) with ESMTP
|
||
id 9D3E55BF5; Wed, 23 Jan 2002 08:35:47 -0800 (PST)
|
||
Date: Wed, 23 Jan 2002 08:35:47 -0800 (PST)
|
||
From: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, <pgsql-hackers@postgresql.org>,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <2600.1011799885@sss.pgh.pa.us>
|
||
Message-ID: <20020123083152.W18169-100000@megazone23.bigpanda.com>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
|
||
On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
|
||
> The only alternative semantics that seem defensible at all are to stop
|
||
> at the first namespace that contains any matching-by-name op or func,
|
||
> and do resolution using only the candidates available in that namespace.
|
||
> That strikes me as not a good idea; for example, a user who defines a
|
||
> "+" operator in his own schema for his own datatype would be quite
|
||
> unhappy to find it masking all the "+" operators in the system schema.
|
||
>
|
||
> I believe that this behavior would be fairly reasonable if our
|
||
> backward-compatibility feature consists of a "public" namespace
|
||
> that all users can write in. OTOH I think it would not play at all
|
||
> well if we use Fernando's idea of an "any" wildcard in the search
|
||
> path. (1) Imagine the case where we have some users who are using
|
||
> the backward-compatible behavior while others have set up private
|
||
> namespaces. If Joe SmartGuy creates a "+" operator in his private
|
||
> namespace, it'll be visible to people using the "any" wildcard and
|
||
> possibly cause resolution-ambiguity failures for them, even though
|
||
> Joe deliberately did what he should do to avoid that. (2) "any"
|
||
> creates the problem of resolving multiple functions with identical
|
||
> signatures in different namespaces, with no reasonable rule for
|
||
> making the choice.
|
||
|
||
Wouldn't it make sense to prefer operators/functions earlier in the search
|
||
path for resolving ambiguity. So if you had plus(int4, int4) in my
|
||
schema and plus(int8, int8) in system, and they'd otherwise cause an
|
||
ambiguity failure for the query, use the plus(int4, int4) on mine. It
|
||
seems not too far from having the search path shadow later exact matches.
|
||
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18041=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 12:18:50 2002
|
||
Return-path: <pgsql-hackers-owner+M18041=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NHInU20563
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 12:18:49 -0500 (EST)
|
||
Received: (qmail 17817 invoked by alias); 23 Jan 2002 17:14:34 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 17:14:34 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NHC6l15615
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 12:12:06 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0NGkwf03162;
|
||
Wed, 23 Jan 2002 11:46:58 -0500 (EST)
|
||
To: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <20020123083152.W18169-100000@megazone23.bigpanda.com>
|
||
References: <20020123083152.W18169-100000@megazone23.bigpanda.com>
|
||
Comments: In-reply-to Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
message dated "Wed, 23 Jan 2002 08:35:47 -0800"
|
||
Date: Wed, 23 Jan 2002 11:46:58 -0500
|
||
Message-ID: <3159.1011804418@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Stephan Szabo <sszabo@megazone23.bigpanda.com> writes:
|
||
> Wouldn't it make sense to prefer operators/functions earlier in the search
|
||
> path for resolving ambiguity. So if you had plus(int4, int4) in my
|
||
> schema and plus(int8, int8) in system, and they'd otherwise cause an
|
||
> ambiguity failure for the query, use the plus(int4, int4) on mine. It
|
||
> seems not too far from having the search path shadow later exact matches.
|
||
|
||
Given the complexity of the resolution rules (cf.
|
||
http://developer.postgresql.org/docs/postgres/typeconv.html),
|
||
it's not clear that we can determine exactly which "later" entry ought
|
||
to be blamed for causing a resolution failure. I'd be interested to
|
||
hear Lockhart's opinion on this --- but my gut feeling is we don't
|
||
want to go there. The resolution rules are already complicated enough,
|
||
and I think layering an additional mechanism like that onto them might
|
||
make the behavior totally unpredictable.
|
||
|
||
Another problem is that this would probably cause earlier namespace
|
||
entries to be over-preferred. For example, suppose that the system
|
||
namespace has plus(int4,int4) and plus(int8,int8) and you choose to
|
||
define plus(int4,int8) locally. I believe you'd suddenly find yours
|
||
being used for *any* cross-datatype addition, including cases that
|
||
had nothing obvious to do with either int4 or int8 ...
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18040=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 12:18:51 2002
|
||
Return-path: <pgsql-hackers-owner+M18040=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NHIoU20594
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 12:18:51 -0500 (EST)
|
||
Received: (qmail 17832 invoked by alias); 23 Jan 2002 17:14:34 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 17:14:34 -0000
|
||
Received: from mx1.relaypoint.net (ns2.generalbroadband.com [64.32.62.5])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NGu6l05540
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 11:56:06 -0500 (EST)
|
||
(envelope-from jconway@cox.net)
|
||
Received: from [206.19.64.3] (account jconway@wwc.com HELO cox.net)
|
||
by mx1.relaypoint.net (CommuniGate Pro SMTP 3.4.8)
|
||
with ESMTP id 2510369; Wed, 23 Jan 2002 08:56:10 -0800
|
||
Message-ID: <3C4EEB2F.8040803@cox.net>
|
||
Date: Wed, 23 Jan 2002 08:56:15 -0800
|
||
From: "Joe Conway (wwc)" <jconway@cox.net>
|
||
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.0; en-US; rv:0.9.6+) Gecko/20011219
|
||
X-Accept-Language: en-us
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <46C15C39FEB2C44BA555E356FBCD6FA41EB4C2@m0114.s-mxs.net> <2677.1011800674@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii; format=flowed
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
|
||
>
|
||
> This would be a *whole* lot simpler if we forgot the notion of "any"
|
||
> and made the search order look like
|
||
>
|
||
> (temp, private, public, system)
|
||
>
|
||
> where the public namespace is world-writable but the private per-user
|
||
> ones are (typically at least) not.
|
||
>
|
||
> It occurs to me that we can get both backward-compatible and SQL92
|
||
> semantics with this same search path; the only thing that needs to
|
||
> be different in the two cases is whether the default place to create
|
||
> objects is your private schema or the public one. If you don't ever
|
||
> use your private schema then it doesn't matter if it's on the search
|
||
> path or not. I would still prefer that the search path be a settable
|
||
> option, since a paranoid person might well wish to not have public in
|
||
> his path at all ... but the default could be as-above.
|
||
>
|
||
|
||
|
||
I think it would be desirable to be able to restrict users from
|
||
"publishing" objects into the public schema. As an admin, I'd like some
|
||
control over the objects in this namespace. Hand-in-hand with this would
|
||
be the ability for the superuser to move (or "promote") an object from a
|
||
private schema to the public one. This would allow a user to develop
|
||
their own objects without interfering with others, but then make it
|
||
public with the superuser's assistance.
|
||
|
||
The search path you suggest above would then lead to the behavior that
|
||
unqualified references to objects will see my own objects before the
|
||
public ones, and other people's private objects must be explicitly
|
||
qualified.
|
||
|
||
Joe
|
||
|
||
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18042=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 12:18:45 2002
|
||
Return-path: <pgsql-hackers-owner+M18042=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NHIiU20532
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 12:18:45 -0500 (EST)
|
||
Received: (qmail 17765 invoked by alias); 23 Jan 2002 17:14:31 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 17:14:31 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NH1Tl11512
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 12:01:29 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0NH0vf03329;
|
||
Wed, 23 Jan 2002 12:00:57 -0500 (EST)
|
||
To: "Joe Conway (wwc)" <jconway@cox.net>
|
||
cc: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C4EEB2F.8040803@cox.net>
|
||
References: <46C15C39FEB2C44BA555E356FBCD6FA41EB4C2@m0114.s-mxs.net> <2677.1011800674@sss.pgh.pa.us> <3C4EEB2F.8040803@cox.net>
|
||
Comments: In-reply-to "Joe Conway (wwc)" <jconway@cox.net>
|
||
message dated "Wed, 23 Jan 2002 08:56:15 -0800"
|
||
Date: Wed, 23 Jan 2002 12:00:56 -0500
|
||
Message-ID: <3326.1011805256@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
"Joe Conway (wwc)" <jconway@cox.net> writes:
|
||
> I think it would be desirable to be able to restrict users from
|
||
> "publishing" objects into the public schema.
|
||
|
||
Sure. I'm envisioning that namespaces will have ACLs --- that's what
|
||
will keep private namespaces private. So, while public would by default
|
||
be world-writable (at least in the backwards-compatibility case),
|
||
there'd be nothing stopping you from marking it as read-only to some
|
||
users.
|
||
|
||
Come to think of it, that's still another reason not to have an "any"
|
||
wildcard: there's no way to put any restrictions on what appears in
|
||
such a namespace.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18043=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 12:22:29 2002
|
||
Return-path: <pgsql-hackers-owner+M18043=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NHMSU21118
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 12:22:28 -0500 (EST)
|
||
Received: (qmail 17648 invoked by alias); 23 Jan 2002 17:14:27 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 17:14:27 -0000
|
||
Received: from megazone.bigpanda.com (megazone.bigpanda.com [63.150.15.178])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NH9Ul15308
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 12:09:30 -0500 (EST)
|
||
(envelope-from sszabo@megazone23.bigpanda.com)
|
||
Received: by megazone.bigpanda.com (Postfix, from userid 1001)
|
||
id E7DB9D5E5; Wed, 23 Jan 2002 09:09:35 -0800 (PST)
|
||
Received: from localhost (localhost [127.0.0.1])
|
||
by megazone.bigpanda.com (Postfix) with ESMTP
|
||
id DD82F5BF5; Wed, 23 Jan 2002 09:09:35 -0800 (PST)
|
||
Date: Wed, 23 Jan 2002 09:09:35 -0800 (PST)
|
||
From: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, <pgsql-hackers@postgresql.org>,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3159.1011804418@sss.pgh.pa.us>
|
||
Message-ID: <20020123085959.U18688-100000@megazone23.bigpanda.com>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
|
||
On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
|
||
> Stephan Szabo <sszabo@megazone23.bigpanda.com> writes:
|
||
> > Wouldn't it make sense to prefer operators/functions earlier in the search
|
||
> > path for resolving ambiguity. So if you had plus(int4, int4) in my
|
||
> > schema and plus(int8, int8) in system, and they'd otherwise cause an
|
||
> > ambiguity failure for the query, use the plus(int4, int4) on mine. It
|
||
> > seems not too far from having the search path shadow later exact matches.
|
||
>
|
||
> Given the complexity of the resolution rules (cf.
|
||
> http://developer.postgresql.org/docs/postgres/typeconv.html),
|
||
> it's not clear that we can determine exactly which "later" entry ought
|
||
> to be blamed for causing a resolution failure. I'd be interested to
|
||
> hear Lockhart's opinion on this --- but my gut feeling is we don't
|
||
> want to go there. The resolution rules are already complicated enough,
|
||
> and I think layering an additional mechanism like that onto them might
|
||
> make the behavior totally unpredictable.
|
||
|
||
> Another problem is that this would probably cause earlier namespace
|
||
> entries to be over-preferred. For example, suppose that the system
|
||
> namespace has plus(int4,int4) and plus(int8,int8) and you choose to
|
||
> define plus(int4,int8) locally. I believe you'd suddenly find yours
|
||
> being used for *any* cross-datatype addition, including cases that
|
||
> had nothing obvious to do with either int4 or int8 ...
|
||
|
||
Well, what I'd been thinking of would have been similar to anywhere it
|
||
says "If only one candidate matches", becoming "If the earliest search
|
||
path entry with at least one candidate matching has only one
|
||
matching candidate ..." But that would cause the plus(int4, int8) to get
|
||
used in any cross-datatype case that could coerce and didn't have a
|
||
stronger match (ie, one of the arguments exactly matching a plus argument
|
||
per b or c) so that's probably not good enough.
|
||
|
||
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M18058=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 14:45:20 2002
|
||
Return-path: <pgsql-hackers-owner+M18058=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NJjJU03694
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 14:45:19 -0500 (EST)
|
||
Received: (qmail 89208 invoked by alias); 23 Jan 2002 19:43:44 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 19:43:44 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0NJd7l87615
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 14:39:07 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 11757 invoked by uid 1130); 23 Jan 2002 19:39:07 -0000
|
||
Date: Wed, 23 Jan 2002 11:34:23 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <12239.1011661590@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201221710360.5119-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Mon, 21 Jan 2002, Tom Lane wrote:
|
||
|
||
> Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> > Remember that a schema is a named representation of ownership, so anything
|
||
> > that can be owned must be in a schema. (Unless you want to invent a
|
||
> > parallel universe for a different kind of ownership, which would be
|
||
> > incredibly confusing.)
|
||
>
|
||
> I don't buy that premise. It's true that SQL92 equates ownership of a
|
||
> schema with ownership of the objects therein, but AFAICS we have no hope
|
||
> of being forward-compatible with existing database setups (wherein there
|
||
> can be multiple tables of different ownership all in a single namespace)
|
||
> if we don't allow varying ownership within a schema. I think we can
|
||
> arrange things so that we are upward compatible with both SQL92 and
|
||
> the old way. Haven't worked out details yet though.
|
||
|
||
Yes we most certianly can! :-)
|
||
|
||
One of the things schemas have to support is essentially a PATH specifier.
|
||
So all we need to do is have all of the schemas created in a new DB have
|
||
path specifiers pulling in all of the other schemas. Thus we can make a
|
||
schema-savy system act as if it has only one namespace.
|
||
|
||
Back when Zembu was paying me to work on this, I envisioned a script or
|
||
tool you'd feed a DB dump, and it would do the schema fixup, including
|
||
adding PATH directives to all schemas, so they all see everything.
|
||
|
||
Since you have to pg_dump when updating, all this adds is running one tool
|
||
during an upgrade. And then existing apps would work. :-)
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18059=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 15:15:34 2002
|
||
Return-path: <pgsql-hackers-owner+M18059=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NKFXU06599
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 15:15:34 -0500 (EST)
|
||
Received: (qmail 357 invoked by alias); 23 Jan 2002 20:13:55 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 20:13:55 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NJvXl94681
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 14:57:33 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0NJvEf05081;
|
||
Wed, 23 Jan 2002 14:57:14 -0500 (EST)
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201221710360.5119-100000@vespasia.home-net.internetconnect.net>
|
||
References: <Pine.NEB.4.33.0201221710360.5119-100000@vespasia.home-net.internetconnect.net>
|
||
Comments: In-reply-to Bill Studenmund <wrstuden@netbsd.org>
|
||
message dated "Wed, 23 Jan 2002 11:34:23 -0800"
|
||
Date: Wed, 23 Jan 2002 14:57:14 -0500
|
||
Message-ID: <5078.1011815834@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> One of the things schemas have to support is essentially a PATH specifier.
|
||
|
||
Yes, but...
|
||
|
||
> So all we need to do is have all of the schemas created in a new DB have
|
||
> path specifiers pulling in all of the other schemas. Thus we can make a
|
||
> schema-savy system act as if it has only one namespace.
|
||
|
||
When you create a new user, do all those path specifiers for the
|
||
existing users magically update themselves? Seems like maintenance
|
||
would be a pain.
|
||
|
||
Fernando's "any" idea is probably a cleaner way to handle it if we
|
||
wanted to do things like that. But I still think it'll be safer and
|
||
more controllable if we provide a "public" namespace instead; see
|
||
followup discussions.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18061=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 16:04:22 2002
|
||
Return-path: <pgsql-hackers-owner+M18061=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NL4LU11265
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 16:04:21 -0500 (EST)
|
||
Received: (qmail 21187 invoked by alias); 23 Jan 2002 21:03:47 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 21:03:47 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0NKkVl14074
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 15:46:32 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 21707 invoked by uid 1130); 23 Jan 2002 20:46:32 -0000
|
||
Date: Wed, 23 Jan 2002 12:41:48 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <648.1011762477@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201231134290.7050-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
|
||
> Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> > Why not? What's wrong with either schema.foo.function (==>
|
||
> > function(schema.foo)) or foo.schema.function (==> schema.function(foo))?
|
||
>
|
||
> Neither is wrong in isolation, but how do you tell the difference?
|
||
> More to the point, given input x.y.z, how do you tell which component
|
||
> is what?
|
||
|
||
See below.
|
||
|
||
> > Tables and functions can't have the same names as schemas,
|
||
>
|
||
> News to me. Where is that written on stone tablets? Even if that's
|
||
|
||
I'm still trying to find the quote, but I found it a few months ago. I'm
|
||
looking in SQL99, which is 1100+ pages for section 2. :-)
|
||
|
||
> considered an acceptable limitation from a purely functional point of
|
||
> view, I don't like using it to disambiguate input. The error messages
|
||
> you'll get from incorrect input to an implementation that depends on
|
||
> that to disambiguate cases will not be very helpful.
|
||
|
||
?? Depends on how we do it. As I see it, we have four cases. In the
|
||
x.y.z.p.q, we have:
|
||
|
||
1) No table name, but a function name. It's a function call.
|
||
|
||
2) A table name, but no function name. It's a table reference.
|
||
|
||
3) Both a table name & function name, and the function is first. I think
|
||
this case is an error (I don't think we support function.foo ==
|
||
function(foo))
|
||
|
||
4) Both a table name & function name, and the table is first. This is
|
||
foo.function.
|
||
|
||
Ok, there is a fifth case, no function nor table names, which is an error.
|
||
|
||
> > Actually functions do have to be schema local. It's in the spec (don't
|
||
> > have exactly where with me).
|
||
>
|
||
> (A) I don't believe that; please cite chapter and verse; (B) even if
|
||
|
||
Peter got to that one first.
|
||
|
||
> SQL92 thinks that's okay, we can't do it that way because of
|
||
> backwards-compatibility issues.
|
||
|
||
Why do backwards-compatability issues keep us from doing it?
|
||
|
||
Yes, I understand we have apps now with different users owning things
|
||
(tables, functions) which they all can access, just like they were in one
|
||
unified name space. With real schemas, they are in differen namespaces.
|
||
But as long as the routines, tables, triggers & such in each schema can
|
||
find things in the other schemas as if they were in one namespace, where
|
||
is the problem? We just have the app gain PATH directives to path in all
|
||
the other schemas.
|
||
|
||
The app runs, even though there are different schemas involved. Where is
|
||
the problem?
|
||
|
||
> > My vote would be to make them schema-specific. As Peter pointed out,
|
||
> > schemas are how you own things,
|
||
>
|
||
> Sorry, but this line of argument is trying to assume the very point in
|
||
> dispute.
|
||
|
||
When you started this thread, you said you were thinking about
|
||
"implementing SQL schemas." Are these "SQL schemas" going to follow the
|
||
spec or not? SQL'99 is rather clear that ownership happens at the schema
|
||
level. Peter spent quite a lot of time last October pounding that into my
|
||
head, and after I looked at the spec, I found he was 100% correct.
|
||
|
||
If these schemas are to follow the standards, ownership happens at the
|
||
schema level. If ownership happens elsewhere, whatever we're doing is not
|
||
following the standard. Unfortunatly it's that cut & dried. So why should
|
||
we call them "SQL schemas" if we aren't following the SQL spec?
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18061=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 16:04:22 2002
|
||
Return-path: <pgsql-hackers-owner+M18061=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NL4LU11264
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 16:04:21 -0500 (EST)
|
||
Received: (qmail 21192 invoked by alias); 23 Jan 2002 21:03:48 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 21:03:48 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NKvHl19546
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 15:57:17 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0NKvGf08536;
|
||
Wed, 23 Jan 2002 15:57:16 -0500 (EST)
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201231134290.7050-100000@vespasia.home-net.internetconnect.net>
|
||
References: <Pine.NEB.4.33.0201231134290.7050-100000@vespasia.home-net.internetconnect.net>
|
||
Comments: In-reply-to Bill Studenmund <wrstuden@netbsd.org>
|
||
message dated "Wed, 23 Jan 2002 12:41:48 -0800"
|
||
Date: Wed, 23 Jan 2002 15:57:16 -0500
|
||
Message-ID: <8533.1011819436@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
>> Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> Why not? What's wrong with either schema.foo.function (==>
|
||
> function(schema.foo)) or foo.schema.function (==> schema.function(foo))?
|
||
>>
|
||
>> Neither is wrong in isolation, but how do you tell the difference?
|
||
>> More to the point, given input x.y.z, how do you tell which component
|
||
>> is what?
|
||
|
||
> ?? Depends on how we do it. As I see it, we have four cases. In the
|
||
> x.y.z.p.q, we have:
|
||
|
||
> 1) No table name, but a function name. It's a function call.
|
||
|
||
> 2) A table name, but no function name. It's a table reference.
|
||
|
||
No, you're missing the point. Which of x,y,z,p,q is the name we
|
||
are going to test to see if it is a table or function? And which
|
||
of these names is a schema name --- if you don't even know that,
|
||
it's hard to argue that checking to see if some name is known is
|
||
a well-defined operation.
|
||
|
||
> When you started this thread, you said you were thinking about
|
||
> "implementing SQL schemas." Are these "SQL schemas" going to follow the
|
||
> spec or not?
|
||
|
||
If you use only the SQL-defined operations, after setting up any
|
||
configuration variables we may invent in the way we will document as
|
||
necessary for SQL-compatible behavior, then you will get SQL-compatible
|
||
behavior. I do not think that precludes having an underlying
|
||
implementation that sees the world differently than SQL does and
|
||
supports non-SQL behaviors too. (For that matter, I'm sure there is
|
||
text somewhere in the spec that points out that the spec intends to
|
||
define user-visible behavior, not implementation.)
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18062=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 16:14:05 2002
|
||
Return-path: <pgsql-hackers-owner+M18062=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NLE4U12279
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 16:14:04 -0500 (EST)
|
||
Received: (qmail 25791 invoked by alias); 23 Jan 2002 21:13:41 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 21:13:41 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0NL3Jl20482
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 16:03:19 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 27532 invoked by uid 1130); 23 Jan 2002 21:03:16 -0000
|
||
Date: Wed, 23 Jan 2002 12:58:33 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <5078.1011815834@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201231242120.7050-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
|
||
> Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> > One of the things schemas have to support is essentially a PATH specifier.
|
||
>
|
||
> Yes, but...
|
||
>
|
||
> > So all we need to do is have all of the schemas created in a new DB have
|
||
> > path specifiers pulling in all of the other schemas. Thus we can make a
|
||
> > schema-savy system act as if it has only one namespace.
|
||
>
|
||
> When you create a new user, do all those path specifiers for the
|
||
> existing users magically update themselves? Seems like maintenance
|
||
> would be a pain.
|
||
|
||
No, they don't. But why should they? Why should they need to?
|
||
|
||
Either we're migrating an existing app, for which adding PATH directives
|
||
with a helper program before restore works, or we're making a new app. If
|
||
you're designing an app for a schema-savy system, you need to think about
|
||
schemas.
|
||
|
||
> Fernando's "any" idea is probably a cleaner way to handle it if we
|
||
> wanted to do things like that. But I still think it'll be safer and
|
||
> more controllable if we provide a "public" namespace instead; see
|
||
> followup discussions.
|
||
|
||
Why? Why is it needed? What would public let you do that PATH and ACLs
|
||
wouldn't?
|
||
|
||
The only reason I can see it's needed is so that people can make new apps
|
||
for a schema-savy PostgreSQL while ignoring the schemas. That strikes me
|
||
as bad. I agree that schemas shouldn't interfeer with things, but to let
|
||
folks just blow them off seems equally bad.
|
||
|
||
Also, it wouldn't be SQL'99 schemas. It can still be done, but it's
|
||
solving a problem that the other SQL'99 databases don't seem to have.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18065=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 16:33:45 2002
|
||
Return-path: <pgsql-hackers-owner+M18065=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NLXiU14151
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 16:33:44 -0500 (EST)
|
||
Received: (qmail 32278 invoked by alias); 23 Jan 2002 21:33:41 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 21:33:41 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0NLKGl28778
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 16:20:16 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 665 invoked by uid 1130); 23 Jan 2002 21:20:17 -0000
|
||
Date: Wed, 23 Jan 2002 13:15:33 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <8533.1011819436@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201231259150.7050-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
|
||
> Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> > On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
> >> Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> > Why not? What's wrong with either schema.foo.function (==>
|
||
> > function(schema.foo)) or foo.schema.function (==> schema.function(foo))?
|
||
> >>
|
||
> >> Neither is wrong in isolation, but how do you tell the difference?
|
||
> >> More to the point, given input x.y.z, how do you tell which component
|
||
> >> is what?
|
||
>
|
||
> > ?? Depends on how we do it. As I see it, we have four cases. In the
|
||
> > x.y.z.p.q, we have:
|
||
>
|
||
> > 1) No table name, but a function name. It's a function call.
|
||
>
|
||
> > 2) A table name, but no function name. It's a table reference.
|
||
>
|
||
> No, you're missing the point. Which of x,y,z,p,q is the name we
|
||
> are going to test to see if it is a table or function? And which
|
||
> of these names is a schema name --- if you don't even know that,
|
||
> it's hard to argue that checking to see if some name is known is
|
||
> a well-defined operation.
|
||
|
||
No, I'm not. :-) You test enough of them to figure out what case you have.
|
||
Yes, it might be a bit of work, but it's doable.
|
||
|
||
Actually, it's not that hard. In foo.funcname, do we support anything
|
||
AFTER the funcname? I don't think so. If there were a parenthesis, then we
|
||
have a function call. If it's an operator or something else, we have
|
||
either a table reference, or a foo.funcname function call. So all we have
|
||
to do is see if p.q (last two elements) is a schema.function, or of q is a
|
||
function pathed into our current schema. If yes, we have foo.function. If
|
||
not, then we have some table reference.
|
||
|
||
> > When you started this thread, you said you were thinking about
|
||
> > "implementing SQL schemas." Are these "SQL schemas" going to follow the
|
||
> > spec or not?
|
||
>
|
||
> If you use only the SQL-defined operations, after setting up any
|
||
> configuration variables we may invent in the way we will document as
|
||
> necessary for SQL-compatible behavior, then you will get SQL-compatible
|
||
> behavior. I do not think that precludes having an underlying
|
||
> implementation that sees the world differently than SQL does and
|
||
> supports non-SQL behaviors too. (For that matter, I'm sure there is
|
||
> text somewhere in the spec that points out that the spec intends to
|
||
> define user-visible behavior, not implementation.)
|
||
|
||
While I agree in principle, that quote is from talking about ownership. I
|
||
don't see how we can gloss over ownership. :-)
|
||
|
||
Also, why support two different behaviors? That means 1) there's code
|
||
bloat since the backend has to support both. 2) Support is harder as major
|
||
DB behaviors will change depending on these settings. 3) I still haven't
|
||
seen anything this variant behavior would do that can't be done with
|
||
schema paths and access control lists, other than it would let people keep
|
||
thinking about things as they do now.
|
||
|
||
That latter reason doesn't strike me as a good one. Yes, it will take some
|
||
getting used to to wrap minds around schemas, but once done, I don't think
|
||
it will be that hard. Yes, the documentation will need work, and the
|
||
tutorial will need changing (And Bruce will need to release a new edition
|
||
of his book :-) , but once that's done, I don't think working with real
|
||
schemas will be that hard. So why not just do things right from the
|
||
begining?
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18064=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 16:23:32 2002
|
||
Return-path: <pgsql-hackers-owner+M18064=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NLNVU13386
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 16:23:31 -0500 (EST)
|
||
Received: (qmail 29442 invoked by alias); 23 Jan 2002 21:23:26 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 21:23:26 -0000
|
||
Received: from stubee.d2hosting.net (d2hosting.net [66.70.41.160])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NLGVl28360
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 16:16:31 -0500 (EST)
|
||
(envelope-from tswan-lst@ics.olemiss.edu)
|
||
Received: from ics.olemiss.edu (adsl-81-102-77.jan.bellsouth.net [65.81.102.77])
|
||
by stubee.d2hosting.net (8.11.6/linuxconf) with ESMTP id g0NLGLT00962;
|
||
Wed, 23 Jan 2002 15:16:22 -0600
|
||
Message-ID: <3C4F2824.90709@ics.olemiss.edu>
|
||
Date: Wed, 23 Jan 2002 15:16:20 -0600
|
||
From: Thomas Swan <tswan-lst@ics.olemiss.edu>
|
||
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.0; en-US; rv:0.9.7+) Gecko/20020123
|
||
X-Accept-Language: en-us
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Stephan Szabo <sszabo@megazone23.bigpanda.com>,
|
||
Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <20020123083152.W18169-100000@megazone23.bigpanda.com> <3159.1011804418@sss.pgh.pa.us>
|
||
Content-Type: text/html; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
||
<html>
|
||
<head>
|
||
<title></title>
|
||
</head>
|
||
<body>
|
||
Tom Lane wrote:<br>
|
||
<blockquote type="cite" cite="mid:3159.1011804418@sss.pgh.pa.us">
|
||
<pre wrap="">Stephan Szabo <a class="moz-txt-link-rfc2396E" href="mailto:sszabo@megazone23.bigpanda.com"><sszabo@megazone23.bigpanda.com></a> writes:<br></pre>
|
||
<blockquote type="cite">
|
||
<pre wrap="">Wouldn't it make sense to prefer operators/functions earlier in the search<br>path for resolving ambiguity. So if you had plus(int4, int4) in my<br>schema and plus(int8, int8) in system, and they'd otherwise cause an<br>ambiguity failure for the query, use the plus(int4, int4) on mine. It<br>seems not too far from having the search path shadow later exact matches.<br></pre>
|
||
</blockquote>
|
||
<pre wrap=""><!----><br>Given the complexity of the resolution rules (cf.<br><a class="moz-txt-link-freetext" href="http://developer.postgresql.org/docs/postgres/typeconv.html">http://developer.postgresql.org/docs/postgres/typeconv.html</a>),<br>it's not clear that we can determine exactly which "later" entry ought<br>to be blamed for causing a resolution failure. I'd be interested to<br>hear Lockhart's opinion on this --- but my gut feeling is we don't<br>want to go there. The resolution rules are already complicated enough,<br>and I think layering an additional mechanism like that onto them might<br>make the behavior totally unpredictable.<br><br>Another problem is that this would probably cause earlier namespace<br>entries to be over-preferred. For example, suppose that the system<br>namespace has plus(int4,int4) and plus(int8,int8) and you choose to<br>define plus(int4,int8) locally. I believe you'd suddenly find yours<br>being used for *any* cross-datatype addit
|
||
ion, including cases that<br>had nothing obvious to do with either int4 or int8 ...<br></pre>
|
||
</blockquote>
|
||
This is a good example. The other option is to use name, arg1, arg2...
|
||
as a hunt path for function call resolution. This would depend on when datatype
|
||
promotion is occuring (i.e. int4 to int8, int8 to int4, etc... )<br>
|
||
<br>
|
||
Then you could just be really hard and say that only exact and trivial conversion
|
||
matches in user space will be used . <br>
|
||
<br>
|
||
There is no easy answer for this, but whatever rules are initiated need to
|
||
be something that someone can step through to solve w/o a machine.<br>
|
||
<br>
|
||
I do think you will ultimately need a search utility that provides 'which'
|
||
functionality. (Given my namespace, which function in what namespace is
|
||
going to be called.)<br>
|
||
<blockquote type="cite" cite="mid:3159.1011804418@sss.pgh.pa.us">
|
||
<pre wrap=""><br><br> regards, tom lane<br><br>---------------------------(end of broadcast)---------------------------<br>TIP 1: subscribe and unsubscribe commands go to <a class="moz-txt-link-abbreviated" href="mailto:majordomo@postgresql.org">majordomo@postgresql.org</a><br></pre>
|
||
</blockquote>
|
||
<br>
|
||
<br>
|
||
</body>
|
||
</html>
|
||
|
||
|
||
From pgsql-hackers-owner+M18066=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 16:45:11 2002
|
||
Return-path: <pgsql-hackers-owner+M18066=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NLjAU15010
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 16:45:11 -0500 (EST)
|
||
Received: (qmail 39170 invoked by alias); 23 Jan 2002 21:43:48 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 21:43:48 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NLQpl30489
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 16:26:51 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0NLQXf08750;
|
||
Wed, 23 Jan 2002 16:26:33 -0500 (EST)
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201231242120.7050-100000@vespasia.home-net.internetconnect.net>
|
||
References: <Pine.NEB.4.33.0201231242120.7050-100000@vespasia.home-net.internetconnect.net>
|
||
Comments: In-reply-to Bill Studenmund <wrstuden@netbsd.org>
|
||
message dated "Wed, 23 Jan 2002 12:58:33 -0800"
|
||
Date: Wed, 23 Jan 2002 16:26:33 -0500
|
||
Message-ID: <8747.1011821193@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> Either we're migrating an existing app, for which adding PATH directives
|
||
> with a helper program before restore works, or we're making a new app.
|
||
|
||
Sorry, I don't accept that either-or proposition. People will expect to
|
||
be able to continue to use 7.3 as they have used Postgres in the past.
|
||
Among other things that will mean being able to add new users to an
|
||
existing installation. If we say "you can't do much of anything in 7.3
|
||
until you upgrade all your applications to schema-awareness", then we're
|
||
going to have lots of unhappy users.
|
||
|
||
>> Fernando's "any" idea is probably a cleaner way to handle it if we
|
||
>> wanted to do things like that. But I still think it'll be safer and
|
||
>> more controllable if we provide a "public" namespace instead; see
|
||
>> followup discussions.
|
||
|
||
> Why? Why is it needed? What would public let you do that PATH and ACLs
|
||
> wouldn't?
|
||
|
||
Public gives you a place to put the ACL determining what people can do
|
||
with publicly-visible names. See, eg, comments from Joe Conway.
|
||
Without a specific public namespace to put ACLs on, a dbadmin has very
|
||
little control over interuser interactions. Please note that the
|
||
facility we are talking about offering here is not available in existing
|
||
Postgres nor in SQL92, but that doesn't make it evil or unreasonable.
|
||
|
||
Basically my point here is that the SQL spec is not the be-all and
|
||
end-all of database development. (Have you read C. J. Date's commentary
|
||
on it, for example?) We have a proven useful concept of object ownership
|
||
in existing Postgres, and I see no need to remove that facility in
|
||
pursuit of slavish adherence to a specification. If it were a project
|
||
goal to rip out everything in Postgres that is not mentioned in the
|
||
SQL spec, we could have a much smaller distribution ... with lots fewer
|
||
users.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18067=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 17:04:34 2002
|
||
Return-path: <pgsql-hackers-owner+M18067=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NM4XU16392
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 17:04:33 -0500 (EST)
|
||
Received: (qmail 47125 invoked by alias); 23 Jan 2002 22:04:32 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 22:04:32 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NLk1l42602
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 16:46:01 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0NLk1f08845;
|
||
Wed, 23 Jan 2002 16:46:01 -0500 (EST)
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201231259150.7050-100000@vespasia.home-net.internetconnect.net>
|
||
References: <Pine.NEB.4.33.0201231259150.7050-100000@vespasia.home-net.internetconnect.net>
|
||
Comments: In-reply-to Bill Studenmund <wrstuden@netbsd.org>
|
||
message dated "Wed, 23 Jan 2002 13:15:33 -0800"
|
||
Date: Wed, 23 Jan 2002 16:46:01 -0500
|
||
Message-ID: <8842.1011822361@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
>> No, you're missing the point. Which of x,y,z,p,q is the name we
|
||
>> are going to test to see if it is a table or function?
|
||
|
||
> No, I'm not. :-) You test enough of them to figure out what case you have.
|
||
|
||
There could be multiple valid interpretations. When you can't even
|
||
figure out where to start, it's too squishy for me. Code complexity
|
||
isn't really the issue here, it's whether a user can understand what's
|
||
going on.
|
||
|
||
> Actually, it's not that hard. In foo.funcname, do we support anything
|
||
> AFTER the funcname? I don't think so. If there were a parenthesis, then we
|
||
> have a function call. If it's an operator or something else, we have
|
||
> either a table reference, or a foo.funcname function call. So all we have
|
||
> to do is see if p.q (last two elements) is a schema.function, or of q is a
|
||
> function pathed into our current schema. If yes, we have foo.function. If
|
||
> not, then we have some table reference.
|
||
|
||
Now wait a sec. What you started out with was the claim
|
||
|
||
> Why not? What's wrong with either schema.foo.function (==>
|
||
> function(schema.foo)) or foo.schema.function (==> schema.function(foo))?
|
||
|
||
The issue was not figuring out whether the last component was a function
|
||
name or not, it was to determine what the other components were, and in
|
||
particular whether the function name should be presumed to be qualified
|
||
(by the next-to-last component taken as a schema name) or unqualified.
|
||
That in turns changes your assumptions about which of the components
|
||
further left are table names, schema names, or catalog names.
|
||
|
||
> ... I don't think working with real
|
||
> schemas will be that hard. So why not just do things right from the
|
||
> begining?
|
||
|
||
If I thought that SQL's model of ownership == namespace was "right",
|
||
then we probably wouldn't be having this argument. I think the spec
|
||
pretty much sucks in this particular department, and I don't see why
|
||
we should restrict our implementation to support only the spec's
|
||
braindead world view. Especially not when it makes the implementation
|
||
harder, not easier, because we end up needing to add in weird frammishes
|
||
to have some semblance of backwards-compatibility too.
|
||
|
||
Please give me some good reasons (not "the spec says so") why it's
|
||
a good idea to treat ownership of a namespace as equivalent to ownership
|
||
of the objects in it, and why decoupling the concepts at the
|
||
implementation level isn't a reasonable thing to do.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18070=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 17:43:52 2002
|
||
Return-path: <pgsql-hackers-owner+M18070=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NMhpU18760
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 17:43:51 -0500 (EST)
|
||
Received: (qmail 53592 invoked by alias); 23 Jan 2002 22:43:08 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 22:43:08 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0NMP4l51662
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 17:25:04 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 9718 invoked by uid 1130); 23 Jan 2002 22:25:06 -0000
|
||
Date: Wed, 23 Jan 2002 14:20:22 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <8842.1011822361@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201231344110.7050-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
|
||
> Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> >> No, you're missing the point. Which of x,y,z,p,q is the name we
|
||
> >> are going to test to see if it is a table or function?
|
||
>
|
||
> > No, I'm not. :-) You test enough of them to figure out what case you have.
|
||
>
|
||
> There could be multiple valid interpretations. When you can't even
|
||
> figure out where to start, it's too squishy for me. Code complexity
|
||
> isn't really the issue here, it's whether a user can understand what's
|
||
> going on.
|
||
>
|
||
> > Actually, it's not that hard. In foo.funcname, do we support anything
|
||
> > AFTER the funcname? I don't think so. If there were a parenthesis, then we
|
||
> > have a function call. If it's an operator or something else, we have
|
||
> > either a table reference, or a foo.funcname function call. So all we have
|
||
> > to do is see if p.q (last two elements) is a schema.function, or of q is a
|
||
> > function pathed into our current schema. If yes, we have foo.function. If
|
||
> > not, then we have some table reference.
|
||
>
|
||
> Now wait a sec. What you started out with was the claim
|
||
>
|
||
> > Why not? What's wrong with either schema.foo.function (==>
|
||
> > function(schema.foo)) or foo.schema.function (==> schema.function(foo))?
|
||
>
|
||
> The issue was not figuring out whether the last component was a function
|
||
> name or not, it was to determine what the other components were, and in
|
||
> particular whether the function name should be presumed to be qualified
|
||
> (by the next-to-last component taken as a schema name) or unqualified.
|
||
> That in turns changes your assumptions about which of the components
|
||
> further left are table names, schema names, or catalog names.
|
||
|
||
Then you choose. Choose a search order, and document it. If you are going
|
||
to go back into a corner full of so much ambiguity, then document your way
|
||
out.
|
||
|
||
You can make it easier restricting say catalogs and schemas to have
|
||
different names, or schemas, tables, and functions can't have the same
|
||
name. For this, I'd suggest following Oracle's example. I don't think you
|
||
can go too wrong using Oracle's behavior to break ties & ambiguities.
|
||
|
||
> > ... I don't think working with real
|
||
> > schemas will be that hard. So why not just do things right from the
|
||
> > begining?
|
||
>
|
||
> If I thought that SQL's model of ownership == namespace was "right",
|
||
> then we probably wouldn't be having this argument. I think the spec
|
||
> pretty much sucks in this particular department, and I don't see why
|
||
> we should restrict our implementation to support only the spec's
|
||
> braindead world view. Especially not when it makes the implementation
|
||
> harder, not easier, because we end up needing to add in weird frammishes
|
||
> to have some semblance of backwards-compatibility too.
|
||
|
||
?? What weird fammishes from ownership?
|
||
|
||
It actually makes things (slightly) simpler. All of the owner fields
|
||
disapear from most system tables, because the owner is implied by the
|
||
containing schema.
|
||
|
||
Also, what is braindead about the spec? Yes, it's not what I would choose,
|
||
and it's different from what PG does now. But it's just that, different.
|
||
Given all of the ACL abilities (if the superuser wants user X to be able
|
||
to create objects in table Y of schema Z, s/he makes it so), why does it
|
||
matter who owns the object?
|
||
|
||
> Please give me some good reasons (not "the spec says so") why it's
|
||
> a good idea to treat ownership of a namespace as equivalent to ownership
|
||
> of the objects in it, and why decoupling the concepts at the
|
||
> implementation level isn't a reasonable thing to do.
|
||
|
||
Can you really give a good reason other than, "I don't like it?"
|
||
|
||
Absent the existance of specs, it's a matter of choice. Having all of the
|
||
ownership happen at the schema level or at the individual item level, it's
|
||
six of one, half-dozen of the other.
|
||
|
||
But there is a spec. A spec that, as far as I can tell, all other
|
||
schema-claming DBs follow. So why shouldn't we follow it? Yes, you don't
|
||
like it. But is this really supposed to be about personal desires, or
|
||
about the resulting DB?
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M18072=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 18:14:00 2002
|
||
Return-path: <pgsql-hackers-owner+M18072=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NNDxU20711
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 18:14:00 -0500 (EST)
|
||
Received: (qmail 61874 invoked by alias); 23 Jan 2002 23:13:20 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 23:13:20 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0NMitl56697
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 17:44:55 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 10914 invoked by uid 1130); 23 Jan 2002 22:44:56 -0000
|
||
Date: Wed, 23 Jan 2002 14:40:12 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, <pgsql-hackers@postgresql.org>,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <2600.1011799885@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201231435300.7050-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
|
||
> Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> > OK, I can accept that. But then I want to get back at my original point,
|
||
> > namely that all database objects (except users and groups) should be in
|
||
> > schemas. This is also cleaner, simpler, and more flexible. There is
|
||
> > clearly demand for schema-local functions. So I think that designing this
|
||
> > system from the premise that a schema-qualified operator call will look
|
||
> > strange is the wrong end to start at.
|
||
>
|
||
> Okay, a fair point --- or you could have used my own argument against
|
||
> me: there's nothing wrong with designing a general mechanism and then
|
||
> choosing not to expose all of the functionality. So let's assume that
|
||
> functions and operators live in namespaces, and that we have some kind
|
||
> of search path across multiple namespaces for use when an unqualified
|
||
> name is given.
|
||
>
|
||
> Now, how is that going to play with resolution of ambiguous calls?
|
||
>
|
||
> The most reasonable semantics I can think of are to collect all the
|
||
> potential matches (matching op/func name) across all the searchable
|
||
> namespaces, discarding only those that have exactly the same signature
|
||
> as one in a prior namespace. Thus, eg, plus(int4,int4) in an earlier
|
||
> namespace would hide plus(int4,int4) in a later namespace in the search
|
||
> path, but it wouldn't hide plus(int8,int8). After we've collected all
|
||
> the visible alternatives, do resolution based on argument types the same
|
||
> way as we do now.
|
||
>
|
||
> The only alternative semantics that seem defensible at all are to stop
|
||
> at the first namespace that contains any matching-by-name op or func,
|
||
> and do resolution using only the candidates available in that namespace.
|
||
> That strikes me as not a good idea; for example, a user who defines a
|
||
> "+" operator in his own schema for his own datatype would be quite
|
||
> unhappy to find it masking all the "+" operators in the system schema.
|
||
|
||
There is a third behavior which is almost the first one. And it's the one
|
||
I use for function matching in the package diffs I made oh so long ago.
|
||
:-)
|
||
|
||
You look in the first namespace for all candidates. If one matches, you
|
||
use it. If two or more match, you throw the error we throw now. If none
|
||
match, you move on to the next namespace and repeat the search there.
|
||
|
||
It's what the code does now. It's not that hard. It's just essentially
|
||
turning part of the function lookup into a for loop over the namespaces.
|
||
:-)
|
||
|
||
It's easier than gathering everything as you only gather one namespace's
|
||
worth of matches at once.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 5: Have you checked our extensive FAQ?
|
||
|
||
http://www.postgresql.org/users-lounge/docs/faq.html
|
||
|
||
From pgsql-hackers-owner+M18071=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 18:14:06 2002
|
||
Return-path: <pgsql-hackers-owner+M18071=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NNE5U20779
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 18:14:06 -0500 (EST)
|
||
Received: (qmail 62072 invoked by alias); 23 Jan 2002 23:13:28 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 23:13:28 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0NMsEl57927
|
||
for <pgsql-hackers@postgresql.org>; Wed, 23 Jan 2002 17:54:14 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 13221 invoked by uid 1130); 23 Jan 2002 22:54:16 -0000
|
||
Date: Wed, 23 Jan 2002 14:49:32 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <2677.1011800674@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201231443440.7050-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
|
||
> "Zeugswetter Andreas SB SD" <ZeugswetterA@spardat.at> writes:
|
||
> > When configured for historical behavior would need to:
|
||
> > 1. have search path: temp, any, system
|
||
> > 2. guard against duplicate table names across all schemas (except temp schema)
|
||
>
|
||
> This would be a *whole* lot simpler if we forgot the notion of "any"
|
||
> and made the search order look like
|
||
>
|
||
> (temp, private, public, system)
|
||
>
|
||
> where the public namespace is world-writable but the private per-user
|
||
> ones are (typically at least) not.
|
||
>
|
||
> It occurs to me that we can get both backward-compatible and SQL92
|
||
> semantics with this same search path; the only thing that needs to
|
||
> be different in the two cases is whether the default place to create
|
||
> objects is your private schema or the public one. If you don't ever
|
||
> use your private schema then it doesn't matter if it's on the search
|
||
> path or not. I would still prefer that the search path be a settable
|
||
> option, since a paranoid person might well wish to not have public in
|
||
> his path at all ... but the default could be as-above.
|
||
|
||
s/public/DEFAULT/ and add a way (createdb option) to make the default ACL
|
||
on DEFAULT such that anyone can create things and we are in agreement.
|
||
|
||
One of the parts of the schema system I'd envisioned (and tried to make)
|
||
was that there would be an IMPLIMENTATION_SCHEMA which owned all
|
||
built-ins, and a DEFAULT schema which was owned by the superuser. Making
|
||
the default schema path for a schema
|
||
IMPLIMENTATION_SCHEMA:<SCHEMA_NAME>:DEFAULT is fine.
|
||
|
||
Making the default schema for creation settable to DEFAULT would be fine,
|
||
and I think would remove objection. :-)
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 5: Have you checked our extensive FAQ?
|
||
|
||
http://www.postgresql.org/users-lounge/docs/faq.html
|
||
|
||
From pgsql-hackers-owner+M18073=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 18:14:19 2002
|
||
Return-path: <pgsql-hackers-owner+M18073=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NNEIU20817
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 18:14:18 -0500 (EST)
|
||
Received: (qmail 61956 invoked by alias); 23 Jan 2002 23:13:23 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 23:13:23 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0NN0Cl58411
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 18:00:12 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 14480 invoked by uid 1130); 23 Jan 2002 23:00:14 -0000
|
||
Date: Wed, 23 Jan 2002 14:55:29 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <8747.1011821193@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201231420310.7050-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
|
||
> Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> > Either we're migrating an existing app, for which adding PATH directives
|
||
> > with a helper program before restore works, or we're making a new app.
|
||
>
|
||
> Sorry, I don't accept that either-or proposition. People will expect to
|
||
> be able to continue to use 7.3 as they have used Postgres in the past.
|
||
> Among other things that will mean being able to add new users to an
|
||
> existing installation. If we say "you can't do much of anything in 7.3
|
||
> until you upgrade all your applications to schema-awareness", then we're
|
||
> going to have lots of unhappy users.
|
||
|
||
"upgrad[ing] .. to schema-awareness" is adding the PATHs to the schema
|
||
creates. You then have a unified namespace (to the apps perspective). The
|
||
migration tool I mentioned should be able to do this (and will need to be
|
||
present).
|
||
|
||
As PostgreSQL changes, people are going to have to learn to deal with new
|
||
features. I really don't think that dealing with schemas is going to be
|
||
that hard. Also, at Zembu, all of the apps we looked at had maybe two or
|
||
three schemas. These are big apps. If they can live with just a few
|
||
schemas, why do we need so many that maintainance is a pain?
|
||
|
||
Also, what is this new user going to do *IN THE EXISTING APP*? Either the
|
||
user is going to change existing tables, for which adding the user to the
|
||
ACLs (or better yet to a group) will work, or the new user is going to own
|
||
new tables. If the new user is owning new tables, then you have to change
|
||
the app to refer to them. If the upgrade to 7.3 included a, "quick
|
||
tutorial about the new schema support," the author should be able to adapt
|
||
easily.
|
||
|
||
> >> Fernando's "any" idea is probably a cleaner way to handle it if we
|
||
> >> wanted to do things like that. But I still think it'll be safer and
|
||
> >> more controllable if we provide a "public" namespace instead; see
|
||
> >> followup discussions.
|
||
>
|
||
> > Why? Why is it needed? What would public let you do that PATH and ACLs
|
||
> > wouldn't?
|
||
>
|
||
> Public gives you a place to put the ACL determining what people can do
|
||
> with publicly-visible names. See, eg, comments from Joe Conway.
|
||
> Without a specific public namespace to put ACLs on, a dbadmin has very
|
||
> little control over interuser interactions. Please note that the
|
||
> facility we are talking about offering here is not available in existing
|
||
> Postgres nor in SQL92, but that doesn't make it evil or unreasonable.
|
||
|
||
I think the existance of a DEFAULT schema (which is a real schema, not a
|
||
special namespace) would also aleviate the above concerns.
|
||
|
||
> Basically my point here is that the SQL spec is not the be-all and
|
||
> end-all of database development. (Have you read C. J. Date's commentary
|
||
> on it, for example?) We have a proven useful concept of object ownership
|
||
> in existing Postgres, and I see no need to remove that facility in
|
||
> pursuit of slavish adherence to a specification. If it were a project
|
||
> goal to rip out everything in Postgres that is not mentioned in the
|
||
> SQL spec, we could have a much smaller distribution ... with lots fewer
|
||
> users.
|
||
|
||
I haven't read the comentary, do you have a URL?
|
||
|
||
I agree that we should not limit ourselves to SQL'99. But doing more than
|
||
SQL'99 is different from wanting to support SQL schemas while using a
|
||
different ownership model, when one of the main things of SQL schemas as I
|
||
understand it is the ownership model.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18075=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 18:33:16 2002
|
||
Return-path: <pgsql-hackers-owner+M18075=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0NNXGU21830
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 18:33:16 -0500 (EST)
|
||
Received: (qmail 68962 invoked by alias); 23 Jan 2002 23:33:14 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 23 Jan 2002 23:33:14 -0000
|
||
Received: from megazone.bigpanda.com (megazone.bigpanda.com [63.150.15.178])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0NNUFl68439
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 18:30:15 -0500 (EST)
|
||
(envelope-from sszabo@megazone23.bigpanda.com)
|
||
Received: by megazone.bigpanda.com (Postfix, from userid 1001)
|
||
id 4D769D5F7; Wed, 23 Jan 2002 15:30:07 -0800 (PST)
|
||
Received: from localhost (localhost [127.0.0.1])
|
||
by megazone.bigpanda.com (Postfix) with ESMTP
|
||
id 412425BF5; Wed, 23 Jan 2002 15:30:07 -0800 (PST)
|
||
Date: Wed, 23 Jan 2002 15:30:07 -0800 (PST)
|
||
From: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>, Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201231435300.7050-100000@vespasia.home-net.internetconnect.net>
|
||
Message-ID: <20020123152711.I22382-100000@megazone23.bigpanda.com>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Bill Studenmund wrote:
|
||
|
||
> On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
>
|
||
> There is a third behavior which is almost the first one. And it's the one
|
||
> I use for function matching in the package diffs I made oh so long ago.
|
||
> :-)
|
||
>
|
||
> You look in the first namespace for all candidates. If one matches, you
|
||
> use it. If two or more match, you throw the error we throw now. If none
|
||
> match, you move on to the next namespace and repeat the search there.
|
||
|
||
That's even more strongly towards earlier namespaces than my suggestion.
|
||
How do you define match? If you allow coercions, then the
|
||
plus(int8, int8) in my schema would be prefered over better (possibly
|
||
exact) matches in the system schema which may not be what you want.
|
||
|
||
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 5: Have you checked our extensive FAQ?
|
||
|
||
http://www.postgresql.org/users-lounge/docs/faq.html
|
||
|
||
From pgsql-hackers-owner+M18078=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 19:04:16 2002
|
||
Return-path: <pgsql-hackers-owner+M18078=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0O04GU23131
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 19:04:16 -0500 (EST)
|
||
Received: (qmail 74730 invoked by alias); 24 Jan 2002 00:03:43 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 24 Jan 2002 00:03:43 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0NNqbl73179
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 18:52:37 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 20343 invoked by uid 1130); 23 Jan 2002 23:52:39 -0000
|
||
Date: Wed, 23 Jan 2002 15:47:55 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>, Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <20020123152711.I22382-100000@megazone23.bigpanda.com>
|
||
Message-ID: <Pine.NEB.4.33.0201231535590.7050-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Stephan Szabo wrote:
|
||
|
||
> On Wed, 23 Jan 2002, Bill Studenmund wrote:
|
||
>
|
||
> > On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
> >
|
||
> > There is a third behavior which is almost the first one. And it's the one
|
||
> > I use for function matching in the package diffs I made oh so long ago.
|
||
> > :-)
|
||
> >
|
||
> > You look in the first namespace for all candidates. If one matches, you
|
||
> > use it. If two or more match, you throw the error we throw now. If none
|
||
> > match, you move on to the next namespace and repeat the search there.
|
||
>
|
||
> That's even more strongly towards earlier namespaces than my suggestion.
|
||
> How do you define match? If you allow coercions, then the
|
||
> plus(int8, int8) in my schema would be prefered over better (possibly
|
||
> exact) matches in the system schema which may not be what you want.
|
||
|
||
True. But:
|
||
|
||
1) How often are you going to make routines with names that duplicate
|
||
those in the system schema, when you don't want them to be used?
|
||
|
||
2) you can always explicitly refer to the system schema, so you can get
|
||
the routine you want if it's not the one you'll get by coercion.
|
||
|
||
3) We tested other (commercial) databases, and they have this behavior, so
|
||
it seems a reasonable thing to do.
|
||
|
||
4) It's simple and easy to understand.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18079=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 19:13:55 2002
|
||
Return-path: <pgsql-hackers-owner+M18079=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0O0DsU23615
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 19:13:55 -0500 (EST)
|
||
Received: (qmail 79143 invoked by alias); 24 Jan 2002 00:13:37 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 24 Jan 2002 00:13:37 -0000
|
||
Received: from megazone.bigpanda.com (megazone.bigpanda.com [63.150.15.178])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0O074l78013
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 19:07:04 -0500 (EST)
|
||
(envelope-from sszabo@megazone23.bigpanda.com)
|
||
Received: by megazone.bigpanda.com (Postfix, from userid 1001)
|
||
id 7D1CFD5F7; Wed, 23 Jan 2002 16:07:07 -0800 (PST)
|
||
Received: from localhost (localhost [127.0.0.1])
|
||
by megazone.bigpanda.com (Postfix) with ESMTP
|
||
id 6EC505BF5; Wed, 23 Jan 2002 16:07:07 -0800 (PST)
|
||
Date: Wed, 23 Jan 2002 16:07:07 -0800 (PST)
|
||
From: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>, Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201231535590.7050-100000@vespasia.home-net.internetconnect.net>
|
||
Message-ID: <20020123155603.Y22713-100000@megazone23.bigpanda.com>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Bill Studenmund wrote:
|
||
|
||
> On Wed, 23 Jan 2002, Stephan Szabo wrote:
|
||
>
|
||
> > On Wed, 23 Jan 2002, Bill Studenmund wrote:
|
||
> >
|
||
> > > On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
> > >
|
||
> > > There is a third behavior which is almost the first one. And it's the one
|
||
> > > I use for function matching in the package diffs I made oh so long ago.
|
||
> > > :-)
|
||
> > >
|
||
> > > You look in the first namespace for all candidates. If one matches, you
|
||
> > > use it. If two or more match, you throw the error we throw now. If none
|
||
> > > match, you move on to the next namespace and repeat the search there.
|
||
> >
|
||
> > That's even more strongly towards earlier namespaces than my suggestion.
|
||
> > How do you define match? If you allow coercions, then the
|
||
> > plus(int8, int8) in my schema would be prefered over better (possibly
|
||
> > exact) matches in the system schema which may not be what you want.
|
||
>
|
||
> True. But:
|
||
>
|
||
> 1) How often are you going to make routines with names that duplicate
|
||
> those in the system schema, when you don't want them to be used?
|
||
|
||
Sure, you want them used when the arguments match, but what about when
|
||
they don't exactly?
|
||
If the system schema has foo(integer) and in my schema I make a new type
|
||
and then make a type(integer) and foo(type), when I call foo(1), do I
|
||
really mean do a coersion to my type and call foo(type)?
|
||
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18082=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 19:33:21 2002
|
||
Return-path: <pgsql-hackers-owner+M18082=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0O0XKU24428
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 19:33:21 -0500 (EST)
|
||
Received: (qmail 85643 invoked by alias); 24 Jan 2002 00:33:19 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 24 Jan 2002 00:33:19 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0O0N0l83366
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 19:23:00 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 24329 invoked by uid 1130); 24 Jan 2002 00:23:02 -0000
|
||
Date: Wed, 23 Jan 2002 16:18:18 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>, Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <20020123155603.Y22713-100000@megazone23.bigpanda.com>
|
||
Message-ID: <Pine.NEB.4.33.0201231606090.7050-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Stephan Szabo wrote:
|
||
|
||
> On Wed, 23 Jan 2002, Bill Studenmund wrote:
|
||
>
|
||
> > True. But:
|
||
> >
|
||
> > 1) How often are you going to make routines with names that duplicate
|
||
> > those in the system schema, when you don't want them to be used?
|
||
>
|
||
> Sure, you want them used when the arguments match, but what about when
|
||
> they don't exactly?
|
||
> If the system schema has foo(integer) and in my schema I make a new type
|
||
> and then make a type(integer) and foo(type), when I call foo(1), do I
|
||
> really mean do a coersion to my type and call foo(type)?
|
||
|
||
Yes, you did. The documentation said that that would happen, so since you
|
||
made the call ambiguous, you wanted the coercion to happen. Or at least
|
||
you weren't concerned that it might.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 5: Have you checked our extensive FAQ?
|
||
|
||
http://www.postgresql.org/users-lounge/docs/faq.html
|
||
|
||
From pgsql-hackers-owner+M18083=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 19:43:17 2002
|
||
Return-path: <pgsql-hackers-owner+M18083=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0O0hGU24835
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 19:43:16 -0500 (EST)
|
||
Received: (qmail 88309 invoked by alias); 24 Jan 2002 00:43:14 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 24 Jan 2002 00:43:14 -0000
|
||
Received: from megazone.bigpanda.com (megazone.bigpanda.com [63.150.15.178])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0O0YUl87134
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 19:34:30 -0500 (EST)
|
||
(envelope-from sszabo@megazone23.bigpanda.com)
|
||
Received: by megazone.bigpanda.com (Postfix, from userid 1001)
|
||
id 11552D5F8; Wed, 23 Jan 2002 16:34:33 -0800 (PST)
|
||
Received: from localhost (localhost [127.0.0.1])
|
||
by megazone.bigpanda.com (Postfix) with ESMTP
|
||
id 050095BF5; Wed, 23 Jan 2002 16:34:33 -0800 (PST)
|
||
Date: Wed, 23 Jan 2002 16:34:32 -0800 (PST)
|
||
From: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>, Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201231606090.7050-100000@vespasia.home-net.internetconnect.net>
|
||
Message-ID: <20020123162426.K22713-100000@megazone23.bigpanda.com>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Bill Studenmund wrote:
|
||
|
||
> On Wed, 23 Jan 2002, Stephan Szabo wrote:
|
||
>
|
||
> > On Wed, 23 Jan 2002, Bill Studenmund wrote:
|
||
> >
|
||
> > > True. But:
|
||
> > >
|
||
> > > 1) How often are you going to make routines with names that duplicate
|
||
> > > those in the system schema, when you don't want them to be used?
|
||
> >
|
||
> > Sure, you want them used when the arguments match, but what about when
|
||
> > they don't exactly?
|
||
> > If the system schema has foo(integer) and in my schema I make a new type
|
||
> > and then make a type(integer) and foo(type), when I call foo(1), do I
|
||
> > really mean do a coersion to my type and call foo(type)?
|
||
>
|
||
> Yes, you did. The documentation said that that would happen, so since you
|
||
|
||
It doesn't currently say anything of the sort. If we made the above
|
||
behavior the standard, it would, but that's sort of circular. ;) Unless
|
||
I'm misreading the page Tom sent me to earlier, it seems to say it
|
||
prefers matches with exact types over coercions which would no longer be
|
||
true.
|
||
|
||
> made the call ambiguous, you wanted the coercion to happen. Or at least
|
||
> you weren't concerned that it might.
|
||
|
||
I still disagree. If I make a complex number type in my schema,
|
||
I don't really intend integer+integer to convert to complex and give me a
|
||
complex answer even if I want to be able to cast integers into complex.
|
||
AFAIK there's no way to specify that I want to make the function
|
||
complex(integer) such that I can do CAST(1 as complex) but not as an
|
||
implicit cast.
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M18084=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 20:06:02 2002
|
||
Return-path: <pgsql-hackers-owner+M18084=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0O161U25898
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 20:06:01 -0500 (EST)
|
||
Received: (qmail 91014 invoked by alias); 24 Jan 2002 01:05:59 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 24 Jan 2002 01:05:59 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0O0qTl89749
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 19:52:29 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 1144 invoked by uid 1130); 24 Jan 2002 00:52:32 -0000
|
||
Date: Wed, 23 Jan 2002 16:47:48 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>, Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <20020123162426.K22713-100000@megazone23.bigpanda.com>
|
||
Message-ID: <Pine.NEB.4.33.0201231636150.7050-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Stephan Szabo wrote:
|
||
|
||
> On Wed, 23 Jan 2002, Bill Studenmund wrote:
|
||
>
|
||
> > On Wed, 23 Jan 2002, Stephan Szabo wrote:
|
||
> >
|
||
> > Yes, you did. The documentation said that that would happen, so since you
|
||
>
|
||
> It doesn't currently say anything of the sort. If we made the above
|
||
> behavior the standard, it would, but that's sort of circular. ;) Unless
|
||
> I'm misreading the page Tom sent me to earlier, it seems to say it
|
||
> prefers matches with exact types over coercions which would no longer be
|
||
> true.
|
||
|
||
The documentation says nothing about schemas at all now, so obviously it
|
||
has to change. :-)
|
||
|
||
> > made the call ambiguous, you wanted the coercion to happen. Or at least
|
||
> > you weren't concerned that it might.
|
||
>
|
||
> I still disagree. If I make a complex number type in my schema,
|
||
> I don't really intend integer+integer to convert to complex and give me a
|
||
> complex answer even if I want to be able to cast integers into complex.
|
||
> AFAIK there's no way to specify that I want to make the function
|
||
> complex(integer) such that I can do CAST(1 as complex) but not as an
|
||
> implicit cast.
|
||
|
||
Note: I've been talking about functions, and you're talking about
|
||
operators. While operators are syntactic sugar for functions, one big
|
||
difference is that you can't specify explicit schemas for operators (nor
|
||
do I think you should be able to). I think exact matches for operators
|
||
anywhere in the path would be better than local coercable ones.
|
||
|
||
Does SQL'99 say anything about this?
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18086=candle.pha.pa.us=pgman@postgresql.org Wed Jan 23 20:25:47 2002
|
||
Return-path: <pgsql-hackers-owner+M18086=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0O1PkU26965
|
||
for <pgman@candle.pha.pa.us>; Wed, 23 Jan 2002 20:25:47 -0500 (EST)
|
||
Received: (qmail 94892 invoked by alias); 24 Jan 2002 01:25:45 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 24 Jan 2002 01:25:45 -0000
|
||
Received: from megazone.bigpanda.com (megazone.bigpanda.com [63.150.15.178])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0O1MNl94162
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 23 Jan 2002 20:22:24 -0500 (EST)
|
||
(envelope-from sszabo@megazone23.bigpanda.com)
|
||
Received: by megazone.bigpanda.com (Postfix, from userid 1001)
|
||
id 5B37BD5F7; Wed, 23 Jan 2002 17:22:26 -0800 (PST)
|
||
Received: from localhost (localhost [127.0.0.1])
|
||
by megazone.bigpanda.com (Postfix) with ESMTP
|
||
id 50EA45BF5; Wed, 23 Jan 2002 17:22:26 -0800 (PST)
|
||
Date: Wed, 23 Jan 2002 17:22:26 -0800 (PST)
|
||
From: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>, Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201231636150.7050-100000@vespasia.home-net.internetconnect.net>
|
||
Message-ID: <20020123165321.K23306-100000@megazone23.bigpanda.com>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Bill Studenmund wrote:
|
||
|
||
What I was getting at was that Tom's behavior (or even mine) is more
|
||
similar to the currently described behavior than the suggested one.
|
||
|
||
> > > made the call ambiguous, you wanted the coercion to happen. Or at least
|
||
> > > you weren't concerned that it might.
|
||
> >
|
||
> > I still disagree. If I make a complex number type in my schema,
|
||
> > I don't really intend integer+integer to convert to complex and give me a
|
||
> > complex answer even if I want to be able to cast integers into complex.
|
||
> > AFAIK there's no way to specify that I want to make the function
|
||
> > complex(integer) such that I can do CAST(1 as complex) but not as an
|
||
> > implicit cast.
|
||
>
|
||
> Note: I've been talking about functions, and you're talking about
|
||
> operators. While operators are syntactic sugar for functions, one big
|
||
> difference is that you can't specify explicit schemas for operators (nor
|
||
> do I think you should be able to). I think exact matches for operators
|
||
> anywhere in the path would be better than local coercable ones.
|
||
|
||
I'd say the same thing for a random math function as well. For example
|
||
if there was a square(int) that returned $1*$1 and I made a square for my
|
||
complex type, I'd still expect that square(5) is an integer rather than a
|
||
complex using the square(complex). For example, I'd expect square(5) to
|
||
be a valid length argument to substr.
|
||
|
||
> Does SQL'99 say anything about this?
|
||
That I don't know about (don't have a draft around to look at). I'm not
|
||
sure that it'd have these problems though unless it's got the same sort of
|
||
coercion system.
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18095=candle.pha.pa.us=pgman@postgresql.org Thu Jan 24 00:43:04 2002
|
||
Return-path: <pgsql-hackers-owner+M18095=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0O5h4U15469
|
||
for <pgman@candle.pha.pa.us>; Thu, 24 Jan 2002 00:43:04 -0500 (EST)
|
||
Received: (qmail 28221 invoked by alias); 24 Jan 2002 05:43:00 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 24 Jan 2002 05:43:00 -0000
|
||
Received: from student.gvsu.edu ([148.61.7.124])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0O5QCl26727
|
||
for <pgsql-hackers@postgreSQL.org>; Thu, 24 Jan 2002 00:26:13 -0500 (EST)
|
||
(envelope-from peter_e@gmx.net)
|
||
Received: from [148.61.250.90] [148.61.250.90] by student.gvsu.edu
|
||
with Novonyx SMTP Server $Revision: 1.3 $; Thu, 24 Jan 2002 00:26:11 -0500 (EDT)
|
||
Date: Thu, 24 Jan 2002 00:28:16 -0500 (EST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
X-Sender: <peter@peter.localdomain>
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Stephan Szabo <sszabo@megazone23.bigpanda.com>,
|
||
Tom Lane <tgl@sss.pgh.pa.us>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201231636150.7050-100000@vespasia.home-net.internetconnect.net>
|
||
Message-ID: <Pine.LNX.4.30.0201240003120.686-100000@peter.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Bill Studenmund writes:
|
||
|
||
> Does SQL'99 say anything about this?
|
||
|
||
Yes, though, as usual, you have to twist your brain a little to understand
|
||
it. My understanding is that for a function call of the form "foo(a, b)"
|
||
it goes like this:
|
||
|
||
1. Find all functions named "foo" in the current database. This is the
|
||
set of "possibly candidate routines".
|
||
|
||
2. Drop all routines that you do not have EXECUTE privilege for. This is
|
||
the set of "executable routines".
|
||
|
||
3. Drop all routines that do not have compatible parameter lists. This is
|
||
the set of "invocable routines".
|
||
|
||
4. Drop all routines whose schema is not in the path. This is the set of
|
||
"candidate routines".
|
||
|
||
5. If you have more than one routine left, eliminate some routines
|
||
according to type precedence rules. (We do some form of this, SQL99
|
||
specifies something different.) This yields the set of "candidate subject
|
||
routines".
|
||
|
||
6. Choose the routine whose schema is earliest in the path as the "subject
|
||
routine".
|
||
|
||
Execute the subject routine. Phew!
|
||
|
||
|
||
This doesn't look glaringly wrong to me, so maybe you want to consider it.
|
||
Please note step 2.
|
||
|
||
--
|
||
Peter Eisentraut peter_e@gmx.net
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18127=candle.pha.pa.us=pgman@postgresql.org Thu Jan 24 14:53:53 2002
|
||
Return-path: <pgsql-hackers-owner+M18127=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0OJrqU16554
|
||
for <pgman@candle.pha.pa.us>; Thu, 24 Jan 2002 14:53:52 -0500 (EST)
|
||
Received: (qmail 59340 invoked by alias); 24 Jan 2002 19:53:33 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 24 Jan 2002 19:53:33 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0OJprl58616
|
||
for <pgsql-hackers@postgreSQL.org>; Thu, 24 Jan 2002 14:51:53 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 22083 invoked by uid 1130); 24 Jan 2002 19:51:54 -0000
|
||
Date: Thu, 24 Jan 2002 11:47:07 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>, Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <20020123165321.K23306-100000@megazone23.bigpanda.com>
|
||
Message-ID: <Pine.NEB.4.33.0201241138130.9384-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Stephan Szabo wrote:
|
||
|
||
> On Wed, 23 Jan 2002, Bill Studenmund wrote:
|
||
>
|
||
> What I was getting at was that Tom's behavior (or even mine) is more
|
||
> similar to the currently described behavior than the suggested one.
|
||
|
||
I understand. As part of developing the package changes, though, I found
|
||
that Oracle used the method I described for finding routines in packages.
|
||
|
||
>From Peter's description, it sounds like Oracle's not following the spec.
|
||
|
||
> I'd say the same thing for a random math function as well. For example
|
||
> if there was a square(int) that returned $1*$1 and I made a square for my
|
||
> complex type, I'd still expect that square(5) is an integer rather than a
|
||
> complex using the square(complex). For example, I'd expect square(5) to
|
||
> be a valid length argument to substr.
|
||
|
||
Yeah, that makes sense.
|
||
|
||
> > Does SQL'99 say anything about this?
|
||
> That I don't know about (don't have a draft around to look at). I'm not
|
||
|
||
Do you want pdfs?
|
||
|
||
> sure that it'd have these problems though unless it's got the same sort of
|
||
> coercion system.
|
||
|
||
I don't think it has the same sort of coercion, but it has some, I'd
|
||
expect (as all of the DBs I know of have some sort of coercion :-)
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18128=candle.pha.pa.us=pgman@postgresql.org Thu Jan 24 15:04:41 2002
|
||
Return-path: <pgsql-hackers-owner+M18128=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0OK4eU18207
|
||
for <pgman@candle.pha.pa.us>; Thu, 24 Jan 2002 15:04:40 -0500 (EST)
|
||
Received: (qmail 65543 invoked by alias); 24 Jan 2002 20:03:53 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 24 Jan 2002 20:03:53 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0OJsul61073
|
||
for <pgsql-hackers@postgreSQL.org>; Thu, 24 Jan 2002 14:54:57 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 23026 invoked by uid 1130); 24 Jan 2002 19:54:57 -0000
|
||
Date: Thu, 24 Jan 2002 11:50:12 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
cc: Stephan Szabo <sszabo@megazone23.bigpanda.com>,
|
||
Tom Lane <tgl@sss.pgh.pa.us>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.LNX.4.30.0201240003120.686-100000@peter.localdomain>
|
||
Message-ID: <Pine.NEB.4.33.0201241147131.9384-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Thu, 24 Jan 2002, Peter Eisentraut wrote:
|
||
|
||
> Bill Studenmund writes:
|
||
>
|
||
> > Does SQL'99 say anything about this?
|
||
>
|
||
> Yes, though, as usual, you have to twist your brain a little to understand
|
||
> it.
|
||
|
||
Indeed. I find the spec makes the most sense after you understand it. ;-)
|
||
|
||
> My understanding is that for a function call of the form "foo(a, b)"
|
||
> it goes like this:
|
||
>
|
||
> 1. Find all functions named "foo" in the current database. This is the
|
||
> set of "possibly candidate routines".
|
||
>
|
||
> 2. Drop all routines that you do not have EXECUTE privilege for. This is
|
||
> the set of "executable routines".
|
||
>
|
||
> 3. Drop all routines that do not have compatible parameter lists. This is
|
||
> the set of "invocable routines".
|
||
>
|
||
> 4. Drop all routines whose schema is not in the path. This is the set of
|
||
> "candidate routines".
|
||
>
|
||
> 5. If you have more than one routine left, eliminate some routines
|
||
> according to type precedence rules. (We do some form of this, SQL99
|
||
> specifies something different.) This yields the set of "candidate subject
|
||
> routines".
|
||
>
|
||
> 6. Choose the routine whose schema is earliest in the path as the "subject
|
||
> routine".
|
||
>
|
||
> Execute the subject routine. Phew!
|
||
|
||
Wow. Thanks for diging this out.
|
||
|
||
> This doesn't look glaringly wrong to me, so maybe you want to consider it.
|
||
> Please note step 2.
|
||
|
||
It looks fine, and is probably what we should do. Well, I'd do things in a
|
||
different order (look only in in-path schemas first for instance), but
|
||
that's just trying to optimize the query. :-)
|
||
|
||
How different are the type coercion rules?
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18156=candle.pha.pa.us=pgman@postgresql.org Thu Jan 24 22:45:56 2002
|
||
Return-path: <pgsql-hackers-owner+M18156=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0P3jte02265
|
||
for <pgman@candle.pha.pa.us>; Thu, 24 Jan 2002 22:45:55 -0500 (EST)
|
||
Received: (qmail 95096 invoked by alias); 25 Jan 2002 03:45:50 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 03:45:50 -0000
|
||
Received: from candle.pha.pa.us (216-55-132-35.dsl.san-diego.abac.net [216.55.132.35])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0P3NWl91448
|
||
for <pgsql-hackers@postgresql.org>; Thu, 24 Jan 2002 22:23:33 -0500 (EST)
|
||
(envelope-from pgman@candle.pha.pa.us)
|
||
Received: (from pgman@localhost)
|
||
by candle.pha.pa.us (8.11.6/8.10.1) id g0P3NMY22893;
|
||
Thu, 24 Jan 2002 22:23:22 -0500 (EST)
|
||
From: Bruce Momjian <pgman@candle.pha.pa.us>
|
||
Message-ID: <200201250323.g0P3NMY22893@candle.pha.pa.us>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <2677.1011800674@sss.pgh.pa.us>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Date: Thu, 24 Jan 2002 22:23:22 -0500 (EST)
|
||
cc: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
pgsql-hackers@postgresql.org
|
||
X-Mailer: ELM [version 2.4ME+ PL96 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
> "Zeugswetter Andreas SB SD" <ZeugswetterA@spardat.at> writes:
|
||
> > When configured for historical behavior would need to:
|
||
> > 1. have search path: temp, any, system
|
||
> > 2. guard against duplicate table names across all schemas (except temp schema)
|
||
>
|
||
> This would be a *whole* lot simpler if we forgot the notion of "any"
|
||
> and made the search order look like
|
||
>
|
||
> (temp, private, public, system)
|
||
>
|
||
> where the public namespace is world-writable but the private per-user
|
||
> ones are (typically at least) not.
|
||
|
||
[ I am just reading this schema thread now.]
|
||
|
||
The above private/public idea seems like a much better than 'any'. That
|
||
'any' thing had me quite confused and the idea thought you would have
|
||
duplicates that would only be found at runtime seems destined to random
|
||
falures.
|
||
|
||
I assume 'private' above means search in my personal schema/namespace.
|
||
|
||
--
|
||
Bruce Momjian | http://candle.pha.pa.us
|
||
pgman@candle.pha.pa.us | (610) 853-3000
|
||
+ If your life is a hard drive, | 830 Blythe Avenue
|
||
+ Christ can be your backup. | Drexel Hill, Pennsylvania 19026
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18157=candle.pha.pa.us=pgman@postgresql.org Thu Jan 24 22:45:56 2002
|
||
Return-path: <pgsql-hackers-owner+M18157=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0P3jte02266
|
||
for <pgman@candle.pha.pa.us>; Thu, 24 Jan 2002 22:45:55 -0500 (EST)
|
||
Received: (qmail 95098 invoked by alias); 25 Jan 2002 03:45:50 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 03:45:50 -0000
|
||
Received: from candle.pha.pa.us (216-55-132-35.dsl.san-diego.abac.net [216.55.132.35])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0P3Qql91635
|
||
for <pgsql-hackers@postgresql.org>; Thu, 24 Jan 2002 22:26:52 -0500 (EST)
|
||
(envelope-from pgman@candle.pha.pa.us)
|
||
Received: (from pgman@localhost)
|
||
by candle.pha.pa.us (8.11.6/8.10.1) id g0P3Qhw23061;
|
||
Thu, 24 Jan 2002 22:26:43 -0500 (EST)
|
||
From: Bruce Momjian <pgman@candle.pha.pa.us>
|
||
Message-ID: <200201250326.g0P3Qhw23061@candle.pha.pa.us>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <2677.1011800674@sss.pgh.pa.us>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Date: Thu, 24 Jan 2002 22:26:43 -0500 (EST)
|
||
cc: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
pgsql-hackers@postgresql.org
|
||
X-Mailer: ELM [version 2.4ME+ PL96 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
> > Or are you thinking about a per session behavior ?
|
||
> > I would rather envision a per database behavior.
|
||
> > Maybe the easy way out would be a "default creation schema" property for
|
||
> > each user, that would default to the username. If you want everything in one
|
||
> > schema simply alter the users.
|
||
>
|
||
> I hadn't really gotten to the point of thinking about exactly what and
|
||
> where the control knobs should be. I suspect you are right that we will
|
||
> want the default behavior to be selectable on a per-user or per-database
|
||
> basis, which seems to eliminate the option of using GUC (at least in its
|
||
> current form). We could easily add a field to pg_shadow or pg_database
|
||
> respectively to determine the default behavior. It'd be nice though if
|
||
> the behavior could be changed after connection by a SET statement, which
|
||
> would be lots easier if the setting were GUC-controlled. Peter, you see
|
||
> any way to resolve that?
|
||
|
||
I think we could set the database default at db creation time, then
|
||
allow SET to modify that default per session; seems flexible enough.
|
||
It is basically a GUC value who's default is stored in pg_database
|
||
rather than postgresql.conf. You could use postgresql.conf to set the
|
||
default schema type at db creation time.
|
||
|
||
--
|
||
Bruce Momjian | http://candle.pha.pa.us
|
||
pgman@candle.pha.pa.us | (610) 853-3000
|
||
+ If your life is a hard drive, | 830 Blythe Avenue
|
||
+ Christ can be your backup. | Drexel Hill, Pennsylvania 19026
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18158=candle.pha.pa.us=pgman@postgresql.org Thu Jan 24 23:03:48 2002
|
||
Return-path: <pgsql-hackers-owner+M18158=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0P43le13410
|
||
for <pgman@candle.pha.pa.us>; Thu, 24 Jan 2002 23:03:47 -0500 (EST)
|
||
Received: (qmail 97941 invoked by alias); 25 Jan 2002 04:03:42 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 04:03:42 -0000
|
||
Received: from student.gvsu.edu ([148.61.7.124])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0P3wjl97273
|
||
for <pgsql-hackers@postgresql.org>; Thu, 24 Jan 2002 22:58:46 -0500 (EST)
|
||
(envelope-from peter_e@gmx.net)
|
||
Received: from [148.61.250.128] [148.61.250.128] by student.gvsu.edu
|
||
with Novonyx SMTP Server $Revision: 1.3 $; Thu, 24 Jan 2002 22:58:51 -0500 (EDT)
|
||
Date: Thu, 24 Jan 2002 23:00:57 -0500 (EST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
X-Sender: <peter@peter.localdomain>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <2677.1011800674@sss.pgh.pa.us>
|
||
Message-ID: <Pine.LNX.4.30.0201242259280.686-100000@peter.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: ORr
|
||
|
||
Tom Lane writes:
|
||
|
||
> It'd be nice though if
|
||
> the behavior could be changed after connection by a SET statement, which
|
||
> would be lots easier if the setting were GUC-controlled. Peter, you see
|
||
> any way to resolve that?
|
||
|
||
We had a text[] field to pg_shadow and/or pg_database containing
|
||
name=value assignments which are executed just before the session starts.
|
||
Doesn't look terribly difficult, and it's something I've always wanted to
|
||
do anyway.
|
||
|
||
--
|
||
Peter Eisentraut peter_e@gmx.net
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18160=candle.pha.pa.us=pgman@postgresql.org Thu Jan 24 23:45:22 2002
|
||
Return-path: <pgsql-hackers-owner+M18160=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0P4jLe11106
|
||
for <pgman@candle.pha.pa.us>; Thu, 24 Jan 2002 23:45:21 -0500 (EST)
|
||
Received: (qmail 3520 invoked by alias); 25 Jan 2002 04:43:35 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 04:43:35 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0P4OAl00294
|
||
for <pgsql-hackers@postgresql.org>; Thu, 24 Jan 2002 23:24:11 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0P4Nef23267;
|
||
Thu, 24 Jan 2002 23:23:40 -0500 (EST)
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
cc: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.LNX.4.30.0201242259280.686-100000@peter.localdomain>
|
||
References: <Pine.LNX.4.30.0201242259280.686-100000@peter.localdomain>
|
||
Comments: In-reply-to Peter Eisentraut <peter_e@gmx.net>
|
||
message dated "Thu, 24 Jan 2002 23:00:57 -0500"
|
||
Date: Thu, 24 Jan 2002 23:23:39 -0500
|
||
Message-ID: <23264.1011932619@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> We [add] a text[] field to pg_shadow and/or pg_database containing
|
||
> name=value assignments which are executed just before the session starts.
|
||
> Doesn't look terribly difficult, and it's something I've always wanted to
|
||
> do anyway.
|
||
|
||
Seems like a fine idea, with many uses besides this one.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M18159=candle.pha.pa.us=pgman@postgresql.org Thu Jan 24 23:33:32 2002
|
||
Return-path: <pgsql-hackers-owner+M18159=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0P4XVe10435
|
||
for <pgman@candle.pha.pa.us>; Thu, 24 Jan 2002 23:33:31 -0500 (EST)
|
||
Received: (qmail 1069 invoked by alias); 25 Jan 2002 04:33:26 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 04:33:26 -0000
|
||
Received: from linuxworld.com.au (www.linuxworld.com.au [203.34.46.50])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0P4Pal00372
|
||
for <pgsql-hackers@postgresql.org>; Thu, 24 Jan 2002 23:25:36 -0500 (EST)
|
||
(envelope-from swm@linuxworld.com.au)
|
||
Received: from localhost (swm@localhost)
|
||
by linuxworld.com.au (8.11.4/8.11.4) with ESMTP id g0P4P5Z12976;
|
||
Fri, 25 Jan 2002 15:25:05 +1100
|
||
Date: Fri, 25 Jan 2002 15:25:05 +1100 (EST)
|
||
From: Gavin Sherry <swm@linuxworld.com.au>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <8533.1011819436@sss.pgh.pa.us>
|
||
Message-ID: <Pine.LNX.4.21.0201251517350.12632-100000@linuxworld.com.au>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 23 Jan 2002, Tom Lane wrote:
|
||
|
||
> If you use only the SQL-defined operations, after setting up any
|
||
> configuration variables we may invent in the way we will document as
|
||
> necessary for SQL-compatible behavior, then you will get SQL-compatible
|
||
> behavior. I do not think that precludes having an underlying
|
||
> implementation that sees the world differently than SQL does and
|
||
> supports non-SQL behaviors too. (For that matter, I'm sure there is
|
||
> text somewhere in the spec that points out that the spec intends to
|
||
> define user-visible behavior, not implementation.)
|
||
|
||
This makes a lot of sense and suggests the possibility of 'schema enabled'
|
||
databases. That is, a switch 'bool withschemas' (which defaults to
|
||
false) could be added to pg_database. If true, the parser and ownership
|
||
model reflects that of SQL'99 and/or the Postgres schema model. If false,
|
||
the existing 'schema' model is assumed.
|
||
|
||
This should allow existing users to migrate their data and applications to
|
||
7.3 without having to modify either.
|
||
|
||
Its not an ideal solution but backward compatibility is generally results
|
||
in compromise ;).
|
||
|
||
Gavin
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18164=candle.pha.pa.us=pgman@postgresql.org Thu Jan 24 23:45:36 2002
|
||
Return-path: <pgsql-hackers-owner+M18164=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0P4jae11220
|
||
for <pgman@candle.pha.pa.us>; Thu, 24 Jan 2002 23:45:36 -0500 (EST)
|
||
Received: (qmail 4119 invoked by alias); 25 Jan 2002 04:43:57 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 04:43:57 -0000
|
||
Received: from candle.pha.pa.us (216-55-132-35.dsl.san-diego.abac.net [216.55.132.35])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0P4Y0l01902
|
||
for <pgsql-hackers@postgresql.org>; Thu, 24 Jan 2002 23:34:00 -0500 (EST)
|
||
(envelope-from pgman@candle.pha.pa.us)
|
||
Received: (from pgman@localhost)
|
||
by candle.pha.pa.us (8.11.6/8.10.1) id g0P4XqD10470;
|
||
Thu, 24 Jan 2002 23:33:52 -0500 (EST)
|
||
From: Bruce Momjian <pgman@candle.pha.pa.us>
|
||
Message-ID: <200201250433.g0P4XqD10470@candle.pha.pa.us>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.LNX.4.30.0201242259280.686-100000@peter.localdomain>
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
Date: Thu, 24 Jan 2002 23:33:52 -0500 (EST)
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>,
|
||
Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, pgsql-hackers@postgresql.org
|
||
X-Mailer: ELM [version 2.4ME+ PL96 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Peter Eisentraut wrote:
|
||
> Tom Lane writes:
|
||
>
|
||
> > It'd be nice though if
|
||
> > the behavior could be changed after connection by a SET statement, which
|
||
> > would be lots easier if the setting were GUC-controlled. Peter, you see
|
||
> > any way to resolve that?
|
||
>
|
||
> We had a text[] field to pg_shadow and/or pg_database containing
|
||
> name=value assignments which are executed just before the session starts.
|
||
> Doesn't look terribly difficult, and it's something I've always wanted to
|
||
> do anyway.
|
||
|
||
So are thinking of "dbname=schema_type"? Seems this is really something
|
||
that should be in pg_database. If you create a database, who wants to
|
||
edit postgresql.conf to set its default schema type? Why not set the
|
||
GUC value from pg_database?
|
||
|
||
--
|
||
Bruce Momjian | http://candle.pha.pa.us
|
||
pgman@candle.pha.pa.us | (610) 853-3000
|
||
+ If your life is a hard drive, | 830 Blythe Avenue
|
||
+ Christ can be your backup. | Drexel Hill, Pennsylvania 19026
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 5: Have you checked our extensive FAQ?
|
||
|
||
http://www.postgresql.org/users-lounge/docs/faq.html
|
||
|
||
From pgsql-hackers-owner+M18165=candle.pha.pa.us=pgman@postgresql.org Fri Jan 25 00:33:36 2002
|
||
Return-path: <pgsql-hackers-owner+M18165=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0P5XZe14335
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 00:33:36 -0500 (EST)
|
||
Received: (qmail 15579 invoked by alias); 25 Jan 2002 05:33:30 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 05:33:30 -0000
|
||
Received: from student.gvsu.edu ([148.61.7.124])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0P5Oul14811
|
||
for <pgsql-hackers@postgreSQL.org>; Fri, 25 Jan 2002 00:24:56 -0500 (EST)
|
||
(envelope-from peter_e@gmx.net)
|
||
Received: from [148.61.250.128] [148.61.250.128] by student.gvsu.edu
|
||
with Novonyx SMTP Server $Revision: 1.3 $; Fri, 25 Jan 2002 00:25:01 -0500 (EDT)
|
||
Date: Fri, 25 Jan 2002 00:27:07 -0500 (EST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
X-Sender: <peter@peter.localdomain>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <8842.1011822361@sss.pgh.pa.us>
|
||
Message-ID: <Pine.LNX.4.30.0201250013040.686-100000@peter.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane writes:
|
||
|
||
> There could be multiple valid interpretations. When you can't even
|
||
> figure out where to start, it's too squishy for me. Code complexity
|
||
> isn't really the issue here, it's whether a user can understand what's
|
||
> going on.
|
||
|
||
Here's a tricky question: In what situations is a.b valid to mean b(a)?
|
||
Because in a general object-like system you could write a.b.c.d to mean
|
||
d(c(b(a))). There you've got a system where it's really impossible to
|
||
tell anything. Maybe b() returns a table, so a.b.c.d could mean
|
||
subattribute d in column c in the table returned by b(a).
|
||
|
||
Somehow we need to do at least one of three things:
|
||
1. Require parentheses after function calls.
|
||
2. Use a different operator to invoke function calls (SQL uses ->).
|
||
3. Require users to register functions as "methods" with the data type
|
||
before being able to say a.b for b(a). This also takes care of having to
|
||
specify the schema of b because that's declared when you define the
|
||
method.
|
||
|
||
SQL99 does 2 and 3 (but not 1).
|
||
|
||
I say, forget Oracle. Oracle doesn't have all the extensibility
|
||
functionality that PostgreSQL has. Let's build a system that is
|
||
consistent, orthogonal, and easy to use for *our* users, and those that
|
||
want to convert will quickly see the value.
|
||
|
||
--
|
||
Peter Eisentraut peter_e@gmx.net
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18166=candle.pha.pa.us=pgman@postgresql.org Fri Jan 25 00:43:38 2002
|
||
Return-path: <pgsql-hackers-owner+M18166=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0P5hce15000
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 00:43:38 -0500 (EST)
|
||
Received: (qmail 18028 invoked by alias); 25 Jan 2002 05:43:28 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 05:43:28 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0P5eol16732
|
||
for <pgsql-hackers@postgreSQL.org>; Fri, 25 Jan 2002 00:40:50 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0P5eIf23724;
|
||
Fri, 25 Jan 2002 00:40:18 -0500 (EST)
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.LNX.4.30.0201250013040.686-100000@peter.localdomain>
|
||
References: <Pine.LNX.4.30.0201250013040.686-100000@peter.localdomain>
|
||
Comments: In-reply-to Peter Eisentraut <peter_e@gmx.net>
|
||
message dated "Fri, 25 Jan 2002 00:27:07 -0500"
|
||
Date: Fri, 25 Jan 2002 00:40:18 -0500
|
||
Message-ID: <23721.1011937218@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> Here's a tricky question: In what situations is a.b valid to mean b(a)?
|
||
|
||
I defined that in my first message on these issues: the last element
|
||
of a dotted-name string can be either a field name or a function
|
||
(which is applied to a table that's the next-to-last item). The
|
||
next-to-last element is always a table name.
|
||
|
||
> Because in a general object-like system you could write a.b.c.d to mean
|
||
> d(c(b(a))).
|
||
|
||
Indeed, that can happen now in Postgres, and as I pointed out we have
|
||
to get rid of it. That doesn't mean we need to eliminate the base case,
|
||
however.
|
||
|
||
> Somehow we need to do at least one of three things:
|
||
> 1. Require parentheses after function calls.
|
||
|
||
Breaks existing code unnecessarily.
|
||
|
||
> 2. Use a different operator to invoke function calls (SQL uses ->).
|
||
|
||
Breaks existing code unnecessarily.
|
||
|
||
> 3. Require users to register functions as "methods" with the data type
|
||
> before being able to say a.b for b(a). This also takes care of having to
|
||
> specify the schema of b because that's declared when you define the
|
||
> method.
|
||
|
||
Doesn't buy you anything unless you intend to reject function
|
||
overloading too. With overloading you may have multiple functions
|
||
b(something), so you still have to be able to determine what a is
|
||
without any context.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M18168=candle.pha.pa.us=pgman@postgresql.org Fri Jan 25 01:13:24 2002
|
||
Return-path: <pgsql-hackers-owner+M18168=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0P6DNe17080
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 01:13:23 -0500 (EST)
|
||
Received: (qmail 22750 invoked by alias); 25 Jan 2002 06:13:23 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 06:13:23 -0000
|
||
Received: from candle.pha.pa.us (216-55-132-35.dsl.san-diego.abac.net [216.55.132.35])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0P5tdl21299
|
||
for <pgsql-hackers@postgresql.org>; Fri, 25 Jan 2002 00:55:39 -0500 (EST)
|
||
(envelope-from pgman@candle.pha.pa.us)
|
||
Received: (from pgman@localhost)
|
||
by candle.pha.pa.us (8.11.6/8.10.1) id g0P5tWY15824;
|
||
Fri, 25 Jan 2002 00:55:32 -0500 (EST)
|
||
From: Bruce Momjian <pgman@candle.pha.pa.us>
|
||
Message-ID: <200201250555.g0P5tWY15824@candle.pha.pa.us>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.LNX.4.30.0201242259280.686-100000@peter.localdomain>
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
Date: Fri, 25 Jan 2002 00:55:32 -0500 (EST)
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>,
|
||
Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, pgsql-hackers@postgresql.org
|
||
X-Mailer: ELM [version 2.4ME+ PL96 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Peter Eisentraut wrote:
|
||
> Tom Lane writes:
|
||
>
|
||
> > It'd be nice though if
|
||
> > the behavior could be changed after connection by a SET statement, which
|
||
> > would be lots easier if the setting were GUC-controlled. Peter, you see
|
||
> > any way to resolve that?
|
||
>
|
||
> We had a text[] field to pg_shadow and/or pg_database containing
|
||
> name=value assignments which are executed just before the session starts.
|
||
> Doesn't look terribly difficult, and it's something I've always wanted to
|
||
> do anyway.
|
||
|
||
Sorry, I see what you are saying now, that the name=value pairs would
|
||
set in pg_database and pg_shadow and get executed on session startup.
|
||
Very good.
|
||
|
||
--
|
||
Bruce Momjian | http://candle.pha.pa.us
|
||
pgman@candle.pha.pa.us | (610) 853-3000
|
||
+ If your life is a hard drive, | 830 Blythe Avenue
|
||
+ Christ can be your backup. | Drexel Hill, Pennsylvania 19026
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18174=candle.pha.pa.us=pgman@postgresql.org Fri Jan 25 06:44:17 2002
|
||
Return-path: <pgsql-hackers-owner+M18174=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0PBiGe20620
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 06:44:16 -0500 (EST)
|
||
Received: (qmail 92210 invoked by alias); 25 Jan 2002 11:43:41 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 11:43:41 -0000
|
||
Received: from smxsat1.smxs.net (smxsat1.smxs.net [213.150.10.1])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0PBYsl90858
|
||
for <pgsql-hackers@postgresql.org>; Fri, 25 Jan 2002 06:34:54 -0500 (EST)
|
||
(envelope-from ZeugswetterA@spardat.at)
|
||
Received: from m01x1.s-mxs.net [10.3.55.201]
|
||
by smxsat1.smxs.net
|
||
with XWall v3.18f ;
|
||
Fri, 25 Jan 2002 12:36:18 +0100
|
||
Received: from m0102.s-mxs.net [10.3.55.2]
|
||
by m01x1.s-mxs.net
|
||
with XWall v3.18a ;
|
||
Fri, 25 Jan 2002 12:34:49 +0100
|
||
Received: from m0114.s-mxs.net ([10.3.55.14]) by m0102.s-mxs.net with Microsoft SMTPSVC(5.0.2195.2966);
|
||
Fri, 25 Jan 2002 12:34:49 +0100
|
||
X-MimeOLE: Produced By Microsoft Exchange V6.0.5762.3
|
||
content-class: urn:content-classes:message
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Date: Fri, 25 Jan 2002 12:34:48 +0100
|
||
Message-ID: <46C15C39FEB2C44BA555E356FBCD6FA42128DD@m0114.s-mxs.net>
|
||
Thread-Topic: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Thread-Index: AcGkLuTMcnCfXPmkTji5zHYd6Vhu3QBZTo9w
|
||
From: "Zeugswetter Andreas SB SD" <ZeugswetterA@spardat.at>
|
||
To: "Joe Conway (wwc)" <jconway@cox.net>, "Tom Lane" <tgl@sss.pgh.pa.us>
|
||
cc: "Fernando Nasser" <fnasser@redhat.com>,
|
||
"Peter Eisentraut" <peter_e@gmx.net>, <pgsql-hackers@postgresql.org>
|
||
X-OriginalArrivalTime: 25 Jan 2002 11:34:49.0376 (UTC) FILETIME=[4C1C7200:01C1A594]
|
||
Content-Transfer-Encoding: 8bit
|
||
X-MIME-Autoconverted: from quoted-printable to 8bit by postgresql.org id g0PBh2m91415
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: ORr
|
||
|
||
|
||
> Tom Lane wrote:
|
||
>
|
||
> >
|
||
> > This would be a *whole* lot simpler if we forgot the notion of "any"
|
||
> > and made the search order look like
|
||
> >
|
||
> > (temp, private, public, system)
|
||
|
||
I am starting to see the advantages and like it. I also like the exact
|
||
name "public" for the public schema.
|
||
|
||
Andreas
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 5: Have you checked our extensive FAQ?
|
||
|
||
http://www.postgresql.org/users-lounge/docs/faq.html
|
||
|
||
From pgsql-hackers-owner+M18195=candle.pha.pa.us=pgman@postgresql.org Fri Jan 25 12:18:20 2002
|
||
Return-path: <pgsql-hackers-owner+M18195=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0PHIJe26232
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 12:18:19 -0500 (EST)
|
||
Received: (qmail 96791 invoked by alias); 25 Jan 2002 17:14:40 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 17:14:40 -0000
|
||
Received: from candle.pha.pa.us (216-55-132-35.dsl.san-diego.abac.net [216.55.132.35])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0PGrXl88459
|
||
for <pgsql-hackers@postgresql.org>; Fri, 25 Jan 2002 11:53:34 -0500 (EST)
|
||
(envelope-from pgman@candle.pha.pa.us)
|
||
Received: (from pgman@localhost)
|
||
by candle.pha.pa.us (8.11.6/8.10.1) id g0PGq4L23522;
|
||
Fri, 25 Jan 2002 11:52:04 -0500 (EST)
|
||
From: Bruce Momjian <pgman@candle.pha.pa.us>
|
||
Message-ID: <200201251652.g0PGq4L23522@candle.pha.pa.us>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <46C15C39FEB2C44BA555E356FBCD6FA42128DD@m0114.s-mxs.net>
|
||
To: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>
|
||
Date: Fri, 25 Jan 2002 11:52:04 -0500 (EST)
|
||
cc: "Joe Conway (wwc)" <jconway@cox.net>, Tom Lane <tgl@sss.pgh.pa.us>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
pgsql-hackers@postgresql.org
|
||
X-Mailer: ELM [version 2.4ME+ PL96 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Zeugswetter Andreas SB SD wrote:
|
||
>
|
||
> > Tom Lane wrote:
|
||
> >
|
||
> > >
|
||
> > > This would be a *whole* lot simpler if we forgot the notion of "any"
|
||
> > > and made the search order look like
|
||
> > >
|
||
> > > (temp, private, public, system)
|
||
>
|
||
> I am starting to see the advantages and like it. I also like the exact
|
||
> name "public" for the public schema.
|
||
|
||
I wonder if we should think about a 'group' area so people in a group
|
||
can create things that others in the group can see, but not people
|
||
outside the group.
|
||
|
||
--
|
||
Bruce Momjian | http://candle.pha.pa.us
|
||
pgman@candle.pha.pa.us | (610) 853-3000
|
||
+ If your life is a hard drive, | 830 Blythe Avenue
|
||
+ Christ can be your backup. | Drexel Hill, Pennsylvania 19026
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From tgl@sss.pgh.pa.us Fri Jan 25 12:04:14 2002
|
||
Return-path: <tgl@sss.pgh.pa.us>
|
||
Received: from sss.pgh.pa.us (root@[192.204.191.242])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id g0PH4De25154
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 12:04:13 -0500 (EST)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0PH4Cf26410;
|
||
Fri, 25 Jan 2002 12:04:12 -0500 (EST)
|
||
To: Bruce Momjian <pgman@candle.pha.pa.us>
|
||
cc: Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
"Joe Conway (wwc)" <jconway@cox.net>, Fernando Nasser <fnasser@redhat.com>,
|
||
Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <200201251652.g0PGq4L23522@candle.pha.pa.us>
|
||
References: <200201251652.g0PGq4L23522@candle.pha.pa.us>
|
||
Comments: In-reply-to Bruce Momjian <pgman@candle.pha.pa.us>
|
||
message dated "Fri, 25 Jan 2002 11:52:04 -0500"
|
||
Date: Fri, 25 Jan 2002 12:04:12 -0500
|
||
Message-ID: <26407.1011978252@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Status: OR
|
||
|
||
Bruce Momjian <pgman@candle.pha.pa.us> writes:
|
||
>> I am starting to see the advantages and like it. I also like the exact
|
||
>> name "public" for the public schema.
|
||
|
||
> I wonder if we should think about a 'group' area so people in a group
|
||
> can create things that others in the group can see, but not people
|
||
> outside the group.
|
||
|
||
I see no reason to hard-wire such a concept. Given createable
|
||
namespaces, ACLs for namespaces, and a settable namespace search path,
|
||
people can set up group namespaces or anything else they want.
|
||
|
||
The (temp, private, public, system) path is suggested as default because
|
||
it's the minimum we need to support both SQL92 and backwards-compatible
|
||
behaviors. I don't think we should put in special-purpose features
|
||
beyond that, when we can instead offer a general mechanism with which
|
||
people can build the special-purpose features they want.
|
||
|
||
regards, tom lane
|
||
|
||
From pgsql-hackers-owner+M18209=candle.pha.pa.us=pgman@postgresql.org Fri Jan 25 16:14:02 2002
|
||
Return-path: <pgsql-hackers-owner+M18209=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0PLE1e19183
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 16:14:01 -0500 (EST)
|
||
Received: (qmail 85059 invoked by alias); 25 Jan 2002 21:13:58 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 21:13:58 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0PKtNl77878
|
||
for <pgsql-hackers@postgresql.org>; Fri, 25 Jan 2002 15:55:23 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 10628 invoked by uid 1130); 25 Jan 2002 20:55:14 -0000
|
||
Date: Fri, 25 Jan 2002 12:50:26 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Gavin Sherry <swm@linuxworld.com.au>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.LNX.4.21.0201251517350.12632-100000@linuxworld.com.au>
|
||
Message-ID: <Pine.NEB.4.33.0201251241140.12100-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Fri, 25 Jan 2002, Gavin Sherry wrote:
|
||
|
||
> This makes a lot of sense and suggests the possibility of 'schema enabled'
|
||
> databases. That is, a switch 'bool withschemas' (which defaults to
|
||
> false) could be added to pg_database. If true, the parser and ownership
|
||
> model reflects that of SQL'99 and/or the Postgres schema model. If false,
|
||
> the existing 'schema' model is assumed.
|
||
>
|
||
> This should allow existing users to migrate their data and applications to
|
||
> 7.3 without having to modify either.
|
||
>
|
||
> Its not an ideal solution but backward compatibility is generally results
|
||
> in compromise ;).
|
||
|
||
I guess my frustration with this idea is that we don't really need it. We
|
||
can achieve the same global namespace for an old app without it. All we
|
||
need is a tool which turns old dumps into new ones (which we probably need
|
||
anyway) that merges all of the schemas together w/ PATH statements. Or
|
||
maybe (new idea) a tool which looks at the schemas in a DB and updates
|
||
their PATHs so they act unified.
|
||
|
||
We can achieve the old behavior w/o having to build it into the backend.
|
||
So why add code to the backend when we don't have to? Among other things,
|
||
it would complicate the system schema as we'd have to keep track of
|
||
ownership values we wouldn't otherwise need to.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From ZeugswetterA@spardat.at Fri Jan 25 16:36:49 2002
|
||
Return-path: <ZeugswetterA@spardat.at>
|
||
Received: from smxsat1.smxs.net (smxsat1.smxs.net [213.150.10.1])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id g0PLame20819
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 16:36:48 -0500 (EST)
|
||
Received: from m01x1.s-mxs.net [10.3.55.201]
|
||
by smxsat1.smxs.net
|
||
with XWall v3.18f ;
|
||
Fri, 25 Jan 2002 22:38:07 +0100
|
||
Received: from m0102.s-mxs.net [10.3.55.2]
|
||
by m01x1.s-mxs.net
|
||
with XWall v3.18a ;
|
||
Fri, 25 Jan 2002 22:36:38 +0100
|
||
Received: from m0114.s-mxs.net ([10.3.55.14]) by m0102.s-mxs.net with Microsoft SMTPSVC(5.0.2195.2966);
|
||
Fri, 25 Jan 2002 22:36:38 +0100
|
||
X-MimeOLE: Produced By Microsoft Exchange V6.0.5762.3
|
||
content-class: urn:content-classes:message
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
Subject: RE: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Date: Fri, 25 Jan 2002 22:36:37 +0100
|
||
Message-ID: <46C15C39FEB2C44BA555E356FBCD6FA42128E0@m0114.s-mxs.net>
|
||
Thread-Topic: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
Thread-Index: AcGlwKXMNIw3BiZ7R4G6MaOhn/ahAgAJ0maA
|
||
From: "Zeugswetter Andreas SB SD" <ZeugswetterA@spardat.at>
|
||
To: "Bruce Momjian" <pgman@candle.pha.pa.us>
|
||
cc: "Joe Conway (wwc)" <jconway@cox.net>, "Tom Lane" <tgl@sss.pgh.pa.us>,
|
||
"Fernando Nasser" <fnasser@redhat.com>,
|
||
"Peter Eisentraut" <peter_e@gmx.net>, <pgsql-hackers@postgresql.org>
|
||
X-OriginalArrivalTime: 25 Jan 2002 21:36:38.0285 (UTC) FILETIME=[5EB2B3D0:01C1A5E8]
|
||
Content-Transfer-Encoding: 8bit
|
||
X-MIME-Autoconverted: from quoted-printable to 8bit by candle.pha.pa.us id g0PLame20819
|
||
Status: OR
|
||
|
||
|
||
> > I am starting to see the advantages and like it. I also like the exact
|
||
> > name "public" for the public schema.
|
||
>
|
||
> I wonder if we should think about a 'group' area so people in a group
|
||
> can create things that others in the group can see, but not people
|
||
> outside the group.
|
||
|
||
A group simply chooses a special schema name for their group.
|
||
|
||
Maybe an extra in the ACL area so you can grant privs for a whole
|
||
schema.
|
||
|
||
grant select on schema blabla to "JoeLuser"
|
||
|
||
Andreas
|
||
|
||
From wrstuden@netbsd.org Fri Jan 25 17:12:51 2002
|
||
Return-path: <wrstuden@netbsd.org>
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0PMCoe23588
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 17:12:51 -0500 (EST)
|
||
Received: (qmail 20909 invoked by uid 1130); 25 Jan 2002 22:12:46 -0000
|
||
Date: Fri, 25 Jan 2002 14:07:58 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Bruce Momjian <pgman@candle.pha.pa.us>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>,
|
||
Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <200201250326.g0P3Qhw23061@candle.pha.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201251358390.12100-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Status: OR
|
||
|
||
On Thu, 24 Jan 2002, Bruce Momjian wrote:
|
||
|
||
> I think we could set the database default at db creation time, then
|
||
> allow SET to modify that default per session; seems flexible enough.
|
||
> It is basically a GUC value who's default is stored in pg_database
|
||
> rather than postgresql.conf. You could use postgresql.conf to set the
|
||
> default schema type at db creation time.
|
||
|
||
Specifically to the question of schema pathing, why would you want it to
|
||
be session-settable? Either your DB app is designed to work w/ schemas, or
|
||
it isn't. That's a pretty fundamental design concept. Given that, I don't
|
||
see how it can make sense to try to operate in the opposite mode as the
|
||
app was designed for - that'll only lead to chaos.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
From tgl@sss.pgh.pa.us Fri Jan 25 17:26:17 2002
|
||
Return-path: <tgl@sss.pgh.pa.us>
|
||
Received: from sss.pgh.pa.us (root@[192.204.191.242])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id g0PMQGe24836
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 17:26:16 -0500 (EST)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0PMQEf07711;
|
||
Fri, 25 Jan 2002 17:26:14 -0500 (EST)
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Bruce Momjian <pgman@candle.pha.pa.us>,
|
||
Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201251358390.12100-100000@vespasia.home-net.internetconnect.net>
|
||
References: <Pine.NEB.4.33.0201251358390.12100-100000@vespasia.home-net.internetconnect.net>
|
||
Comments: In-reply-to Bill Studenmund <wrstuden@netbsd.org>
|
||
message dated "Fri, 25 Jan 2002 14:07:58 -0800"
|
||
Date: Fri, 25 Jan 2002 17:26:14 -0500
|
||
Message-ID: <7708.1011997574@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Status: OR
|
||
|
||
Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> Specifically to the question of schema pathing, why would you want it to
|
||
> be session-settable? Either your DB app is designed to work w/ schemas, or
|
||
> it isn't.
|
||
|
||
So that you can set the correct mode for your client application. It is
|
||
silly to suppose that an installation-wide or even database-wide setting
|
||
is sufficient. Consider for example a database shared by multiple
|
||
pieces of client software; wouldn't you like to be able to upgrade them
|
||
to schema-awareness one at a time?
|
||
|
||
You could possibly make a case for a single setting per user, but even
|
||
that makes an assumption (user == client software) that I think is not
|
||
reasonable for us to force on all Postgres installations.
|
||
|
||
Basically I haven't got a lot of patience for arguments that say we do
|
||
not need flexibility. There are more people out there, using Postgres
|
||
in more different ways, than either you or I know about.
|
||
|
||
regards, tom lane
|
||
|
||
From pgsql-hackers-owner+M18216=candle.pha.pa.us=pgman@postgresql.org Fri Jan 25 18:54:34 2002
|
||
Return-path: <pgsql-hackers-owner+M18216=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0PNsXe02286
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 18:54:34 -0500 (EST)
|
||
Received: (qmail 18323 invoked by alias); 25 Jan 2002 23:53:56 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 25 Jan 2002 23:53:56 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0PNk1l17143
|
||
for <pgsql-hackers@postgresql.org>; Fri, 25 Jan 2002 18:46:02 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 23281 invoked by uid 1130); 25 Jan 2002 23:46:04 -0000
|
||
Date: Fri, 25 Jan 2002 15:41:16 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Bruce Momjian <pgman@candle.pha.pa.us>,
|
||
Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <7708.1011997574@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201251425391.12100-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Fri, 25 Jan 2002, Tom Lane wrote:
|
||
|
||
> Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> > Specifically to the question of schema pathing, why would you want it to
|
||
> > be session-settable? Either your DB app is designed to work w/ schemas, or
|
||
> > it isn't.
|
||
>
|
||
> So that you can set the correct mode for your client application. It is
|
||
> silly to suppose that an installation-wide or even database-wide setting
|
||
> is sufficient. Consider for example a database shared by multiple
|
||
> pieces of client software; wouldn't you like to be able to upgrade them
|
||
> to schema-awareness one at a time?
|
||
|
||
What exactly does it mean to upgrade to schema-awareness? I know the jist
|
||
of what you mean, but what does it entail? What steps? I ask as, when I
|
||
think of what it means in practical steps, an upgraded app won't have
|
||
problems with extra stuff pathed in. So the upgraded app will be fine with
|
||
the pathing set up to include all (not-upgraded) schemas. Also, if it does
|
||
have a problem with stuff pathed in, since you can easily set the new apps
|
||
up to live in different schemas than the old ones, you can have upgraded &
|
||
from-before schemas.
|
||
|
||
> You could possibly make a case for a single setting per user, but even
|
||
> that makes an assumption (user == client software) that I think is not
|
||
> reasonable for us to force on all Postgres installations.
|
||
|
||
But we will have the ability to set the path per schema. Since
|
||
schema-aware apps should be able to choose which schema they connect to (I
|
||
envision it being a connect parameter), the different apps can implicitly
|
||
get different behaviors by connecting to schemas that are designed to be
|
||
schema-savy, or connecting to ones which aren't (i.e. have all of the
|
||
schema-unaware stuff pathed in).
|
||
|
||
> Basically I haven't got a lot of patience for arguments that say we do
|
||
> not need flexibility. There are more people out there, using Postgres
|
||
> in more different ways, than either you or I know about.
|
||
|
||
Tom, please listen to what I'm saying. I'm trying to be as clear as I can
|
||
& making sure I'm not working from details in my head and not my posts.
|
||
I'm sorry if it isn't clear but I'm _not_ saying that we don't need the
|
||
flexability you describe. We do.
|
||
|
||
I'm saying that IT IS ALREADY THERE! The pathing built into schemas can be
|
||
very powerful. Powerful enough that I haven't heard of an example yet that
|
||
can't be taken care of with judicious use of pathing. And I don't think
|
||
the pathing needed is beyond mid-level admins (I don't see it as something
|
||
which only say 5 people on the lists can get right). Yes, people will have
|
||
to learn it, but it doesn't strike me as that hard a thing.
|
||
|
||
What I am saying is that we don't need the solution you & Bruce mentioned
|
||
to get the flexability you mentioned as the reason for adding it. So why
|
||
add the feature which isn't needed?
|
||
|
||
One of my objections to a "mode" supporting the old behavior is that, as I
|
||
understand it, there would be a schema ("public") where different users
|
||
could own objects in the same schema. That goes against one of the
|
||
advantages I see for schemas: we can consolidate ownership info in the
|
||
system tables. If you know what schema something is in, you know its
|
||
owner. That means that adding schema support doesn't mean growing system
|
||
tables, just renaming a column (the user id gets turned into the schema
|
||
id).
|
||
|
||
Maybe that's not such a big deal. But it seems when we're doing things
|
||
right, things should get cleaner. Having to keep ownership info at both
|
||
the schema level and at the object level strikes me as not making things
|
||
cleaner. That just seems to be going in the wrong direction.
|
||
|
||
Especially as, AFAICT, it wouldn't be hard to let the sysadmins have all
|
||
the flexability you want them to have (and also that I agree they should
|
||
have) in a system which is, at its core, very schema-savy (everything in
|
||
one schema is owned by the same user or group).
|
||
|
||
I also agree that migration is important. Apps from 7.2 (and 7.1 and
|
||
earlier as possible) should run on the schema-savy backend I describe. A
|
||
migration tool to take the dump from before and add update schema commands
|
||
to path everything in (so it looks like one namespace) should make the old
|
||
apps keep working.
|
||
|
||
The one thing I'll concede could be useful would be for createuser to be
|
||
told to automatically set the new user's schema to include all the other
|
||
schemas, and to update all the other user schemas to add this user. That
|
||
way you can add new users to your DB when you're acting as if it didn't
|
||
have schemas.
|
||
|
||
Hmmm. If we made the above behavior a per-db-configurable default, the
|
||
pg_dump file wouldn't need to be changed. That would be good. It would
|
||
make the path updates O(nusers^2) rather than O(nusers), but that probably
|
||
won't be bad. And offering both options would probably be good.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From tgl@sss.pgh.pa.us Fri Jan 25 19:04:17 2002
|
||
Return-path: <tgl@sss.pgh.pa.us>
|
||
Received: from sss.pgh.pa.us (root@[192.204.191.242])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with ESMTP id g0Q04Ge02926
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 19:04:17 -0500 (EST)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0Q04Ff08236;
|
||
Fri, 25 Jan 2002 19:04:16 -0500 (EST)
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Bruce Momjian <pgman@candle.pha.pa.us>,
|
||
Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
pgsql-hackers@postgresql.org
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <Pine.NEB.4.33.0201251425391.12100-100000@vespasia.home-net.internetconnect.net>
|
||
References: <Pine.NEB.4.33.0201251425391.12100-100000@vespasia.home-net.internetconnect.net>
|
||
Comments: In-reply-to Bill Studenmund <wrstuden@netbsd.org>
|
||
message dated "Fri, 25 Jan 2002 15:41:16 -0800"
|
||
Date: Fri, 25 Jan 2002 19:04:15 -0500
|
||
Message-ID: <8233.1012003455@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Status: OR
|
||
|
||
Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> But we will have the ability to set the path per schema.
|
||
|
||
?? I don't follow that at all. A namespace is something that's referred
|
||
to by a search path, not vice versa. Or are you defining "schema" to
|
||
mean some higher-level concept that incorporates a search path of
|
||
multiple primitive namespaces? Maybe that could work, but I'm not sure
|
||
I see the point yet.
|
||
|
||
regards, tom lane
|
||
|
||
From wrstuden@netbsd.org Fri Jan 25 20:39:59 2002
|
||
Return-path: <wrstuden@netbsd.org>
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0Q1dve10731
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 20:39:58 -0500 (EST)
|
||
Received: (qmail 27927 invoked by uid 1130); 26 Jan 2002 01:39:59 -0000
|
||
Date: Fri, 25 Jan 2002 17:35:11 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Bruce Momjian <pgman@candle.pha.pa.us>,
|
||
Zeugswetter Andreas SB SD <ZeugswetterA@spardat.at>,
|
||
Fernando Nasser <fnasser@redhat.com>, Peter Eisentraut <peter_e@gmx.net>,
|
||
<pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <8233.1012003455@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201251631050.12100-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Status: OR
|
||
|
||
On Fri, 25 Jan 2002, Tom Lane wrote:
|
||
|
||
> Bill Studenmund <wrstuden@netbsd.org> writes:
|
||
> > But we will have the ability to set the path per schema.
|
||
>
|
||
> ?? I don't follow that at all. A namespace is something that's referred
|
||
> to by a search path, not vice versa. Or are you defining "schema" to
|
||
> mean some higher-level concept that incorporates a search path of
|
||
> multiple primitive namespaces? Maybe that could work, but I'm not sure
|
||
> I see the point yet.
|
||
|
||
Oh. That would make a difference. We've been talking past each other.
|
||
|
||
SQL schemas, as I understand the spec, are both. A shema is a container
|
||
that holds things like tables and views and functions (and for PostgreSQL
|
||
operators and aggregates and I'd suggest index operators, etc.). It also
|
||
can include a schema path specification, which defines the search path
|
||
used by routines (stored procedures & functions) contained in that schema.
|
||
|
||
So say I have schemas foo, bar, and baz. I can set the schema path for
|
||
schema bar to be foo:bar:baz:IMPLIMENTATION_SCHEMA, and all routines in
|
||
bar will look in those four schemas for types, functions and tables (and
|
||
everything else we use the search path for).
|
||
|
||
(*) IMPLIMENTATION_SCHEMA is required by the spec, and contains all the
|
||
built-ins. It's be implimentation_schema for pg. Also, if you have a path
|
||
that doesn't list it, the db is supposed to prepend it to the list.
|
||
|
||
So when migrating an app from a schema-unaware PostgreSQL to a
|
||
schema-aware one, if we create a schema for each user, and make each
|
||
such schema path in all the other such schemas, we make it such that all
|
||
of the procedures in those schemas act like they have a unified namespace.
|
||
|
||
There also is also the concept of the CURRENT_PATH which is the schema
|
||
path used for parsed queries (like ones typed into psql). I got lost in
|
||
the spec trying to find what this is supposed to default to, but what I
|
||
understand other DBs to do is your CURRENT_PATH is set to the path of the
|
||
schema you log into.
|
||
|
||
Add to this mix the default schema for user X is schema X (which I thought
|
||
was in the spec but I can't find now), and let's look at that example
|
||
again.
|
||
|
||
Say we had users foo, bar and baz before. We made schemas foo, bar, and
|
||
baz. We set the default paths for each of these schemas to
|
||
foo:bar:baz:IMPLIMENTATION_SCHEMA. Now the routines in each of these
|
||
schemas will see a unified namespace. Next, when we log in as users foo,
|
||
bar, or baz, and our CURRENT_PATH ends up including the namespaces of the
|
||
three original users. So now all of our submitted queries also see a
|
||
unified namespace.
|
||
|
||
So with a schema-savy backend, by adding PATH statements to the schemas
|
||
that pull in all of the previous schemas, we can make the old app behave
|
||
as if it had a unified namespace.
|
||
|
||
Does that make sense?
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
P.S. does anyone need copies of the spec? I found pdf's on the web a while
|
||
back..
|
||
|
||
|
||
From pgsql-hackers-owner+M18221=candle.pha.pa.us=pgman@postgresql.org Fri Jan 25 22:13:58 2002
|
||
Return-path: <pgsql-hackers-owner+M18221=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0Q3Dwe17302
|
||
for <pgman@candle.pha.pa.us>; Fri, 25 Jan 2002 22:13:58 -0500 (EST)
|
||
Received: (qmail 42344 invoked by alias); 26 Jan 2002 03:13:55 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 26 Jan 2002 03:13:55 -0000
|
||
Received: from golem.fourpalms.org (golem.fourpalms.org [64.3.68.148])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0Q35hl41629
|
||
for <pgsql-hackers@postgresql.org>; Fri, 25 Jan 2002 22:05:43 -0500 (EST)
|
||
(envelope-from lockhart@fourpalms.org)
|
||
Received: from fourpalms.org (localhost.localdomain [127.0.0.1])
|
||
by golem.fourpalms.org (Postfix) with ESMTP
|
||
id 0336CFEC5; Sat, 26 Jan 2002 03:05:45 +0000 (UTC)
|
||
Message-ID: <3C521D08.9138E2EA@fourpalms.org>
|
||
Date: Sat, 26 Jan 2002 03:05:44 +0000
|
||
From: Thomas Lockhart <lockhart@fourpalms.org>
|
||
Reply-To: lockhart@fourpalms.org
|
||
Organization: Yes
|
||
X-Mailer: Mozilla 4.75 [en] (X11; U; Linux 2.2.17-21mdksmp i686)
|
||
X-Accept-Language: en
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Stephan Szabo <sszabo@megazone23.bigpanda.com>,
|
||
Peter Eisentraut <peter_e@gmx.net>, pgsql-hackers@postgresql.org,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <20020123083152.W18169-100000@megazone23.bigpanda.com> <3159.1011804418@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
...
|
||
> > Wouldn't it make sense to prefer operators/functions earlier in the search
|
||
> > path for resolving ambiguity. So if you had plus(int4, int4) in my
|
||
> > schema and plus(int8, int8) in system, and they'd otherwise cause an
|
||
> > ambiguity failure for the query, use the plus(int4, int4) on mine. It
|
||
> > seems not too far from having the search path shadow later exact matches.
|
||
> Given the complexity of the resolution rules (cf.
|
||
> http://developer.postgresql.org/docs/postgres/typeconv.html),
|
||
> it's not clear that we can determine exactly which "later" entry ought
|
||
> to be blamed for causing a resolution failure. I'd be interested to
|
||
> hear Lockhart's opinion on this --- but my gut feeling is we don't
|
||
> want to go there. The resolution rules are already complicated enough,
|
||
> and I think layering an additional mechanism like that onto them might
|
||
> make the behavior totally unpredictable.
|
||
|
||
(I've been following the discussion; I suspect that this part may
|
||
already have an obvious answer since "any" scoping -- equivalent to
|
||
flattening the namespace? -- may now be out of favor; I'm assuming that
|
||
we have a clearly scoped lookup scheme available).
|
||
|
||
imho there is nothing fundamentally difficult or "unpredictable" about
|
||
layering schema lookup on to the existing function resolution rules. One
|
||
might want a bit better diagnostics about *which* function was actually
|
||
chosen, but reasonable scoping and lookup rules could be constructed
|
||
which give reasonable behavior with the addition of schemas.
|
||
|
||
For example, the current function resolution rules prefer an exact
|
||
match, then start looking for approximate matches, and narrow that down
|
||
to preferring the one with the best explicit match on data types. If
|
||
more than one matches, then it rejects the query. (I've left out one or
|
||
two steps, but on the whole this is the behavior that matters.)
|
||
|
||
With schemas, one could choose to use "closest schema" as the tiebreaker
|
||
for multiple matches, but istm that an exact match should always win.
|
||
|
||
We might want to include a mechanism that *blocks* schema lookups deeper
|
||
into the search path, to allow reliable *complete replacement* of a
|
||
function. This would be a property of the function, to be set when it is
|
||
defined in the schema. So an implementer could choose to restrict
|
||
lookups explicitly if that is deemed necessary. Again, this is not a
|
||
huge complication.
|
||
|
||
It is an interesting discussion, and the fine points will not be brought
|
||
out without having lots of back-and-forth, which seems to be happening
|
||
already ;)
|
||
|
||
- Thomas
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18236=candle.pha.pa.us=pgman@postgresql.org Sun Jan 27 20:44:07 2002
|
||
Return-path: <pgsql-hackers-owner+M18236=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0S1i6e21103
|
||
for <pgman@candle.pha.pa.us>; Sun, 27 Jan 2002 20:44:06 -0500 (EST)
|
||
Received: (qmail 86523 invoked by alias); 28 Jan 2002 01:44:01 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 28 Jan 2002 01:44:01 -0000
|
||
Received: from sd.tpf.co.jp (sd.tpf.co.jp [210.161.239.34])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0S1X4l84668
|
||
for <pgsql-hackers@postgreSQL.org>; Sun, 27 Jan 2002 20:33:04 -0500 (EST)
|
||
(envelope-from Inoue@tpf.co.jp)
|
||
Received: (qmail 4010 invoked from network); 28 Jan 2002 01:33:07 -0000
|
||
Received: from unknown (HELO viscomail.tpf.co.jp) (100.0.0.108)
|
||
by sd2.tpf-fw-c.co.jp with SMTP; 28 Jan 2002 01:33:07 -0000
|
||
Received: from tpf.co.jp (3dgateway1 [126.0.1.60])
|
||
by viscomail.tpf.co.jp (8.8.8+Sun/8.8.8) with ESMTP id KAA05318;
|
||
Mon, 28 Jan 2002 10:33:04 +0900 (JST)
|
||
Message-ID: <3C54AA51.64CE68AD@tpf.co.jp>
|
||
Date: Mon, 28 Jan 2002 10:33:05 +0900
|
||
From: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
X-Mailer: Mozilla 4.73 [ja] (Windows NT 5.0; U)
|
||
X-Accept-Language: ja
|
||
MIME-Version: 1.0
|
||
To: Peter Eisentraut <peter_e@gmx.net>, Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>,
|
||
Stephan Szabo <sszabo@megazone23.bigpanda.com>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.LNX.4.30.0201240003120.686-100000@peter.localdomain>
|
||
Content-Type: text/plain; charset=iso-2022-jp
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Is *the path* below the same as "search path* in other
|
||
postings about this thread ?
|
||
|
||
Maybe Peter's posting isn't the one exactly what I have to
|
||
ask but there are too many postings for me to follow.
|
||
|
||
regards,
|
||
Hiroshi Inoue
|
||
|
||
Peter Eisentraut wrote:
|
||
>
|
||
> Bill Studenmund writes:
|
||
>
|
||
> > Does SQL'99 say anything about this?
|
||
>
|
||
> Yes, though, as usual, you have to twist your brain a little to understand
|
||
> it. My understanding is that for a function call of the form "foo(a, b)"
|
||
> it goes like this:
|
||
>
|
||
> 1. Find all functions named "foo" in the current database. This is the
|
||
> set of "possibly candidate routines".
|
||
>
|
||
> 2. Drop all routines that you do not have EXECUTE privilege for. This is
|
||
> the set of "executable routines".
|
||
>
|
||
> 3. Drop all routines that do not have compatible parameter lists. This is
|
||
> the set of "invocable routines".
|
||
>
|
||
> 4. Drop all routines whose schema is not in the path. This is the set of
|
||
> "candidate routines".
|
||
>
|
||
> 5. If you have more than one routine left, eliminate some routines
|
||
> according to type precedence rules. (We do some form of this, SQL99
|
||
> specifies something different.) This yields the set of "candidate subject
|
||
> routines".
|
||
>
|
||
> 6. Choose the routine whose schema is earliest in the path as the "subject
|
||
> routine".
|
||
>
|
||
> Execute the subject routine. Phew!
|
||
>
|
||
> This doesn't look glaringly wrong to me, so maybe you want to consider it.
|
||
> Please note step 2.
|
||
>
|
||
> --
|
||
> Peter Eisentraut peter_e@gmx.net
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18249=candle.pha.pa.us=pgman@postgresql.org Mon Jan 28 19:34:59 2002
|
||
Return-path: <pgsql-hackers-owner+M18249=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0T0Ywe04781
|
||
for <pgman@candle.pha.pa.us>; Mon, 28 Jan 2002 19:34:58 -0500 (EST)
|
||
Received: (qmail 99270 invoked by alias); 29 Jan 2002 00:34:49 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 29 Jan 2002 00:34:49 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0T0WDl98697
|
||
for <pgsql-hackers@postgreSQL.org>; Mon, 28 Jan 2002 19:32:13 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 26513 invoked by uid 1130); 29 Jan 2002 00:31:57 -0000
|
||
Date: Mon, 28 Jan 2002 16:27:04 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, Tom Lane <tgl@sss.pgh.pa.us>,
|
||
Stephan Szabo <sszabo@megazone23.bigpanda.com>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C54AA51.64CE68AD@tpf.co.jp>
|
||
Message-ID: <Pine.NEB.4.33.0201281624010.18868-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Mon, 28 Jan 2002, Hiroshi Inoue wrote:
|
||
|
||
> Is *the path* below the same as "search path* in other
|
||
> postings about this thread ?
|
||
|
||
I think so. I believe the path I've been talking about is the one in step
|
||
6 below.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
> Maybe Peter's posting isn't the one exactly what I have to
|
||
> ask but there are too many postings for me to follow.
|
||
>
|
||
> regards,
|
||
> Hiroshi Inoue
|
||
>
|
||
> Peter Eisentraut wrote:
|
||
> >
|
||
> > Bill Studenmund writes:
|
||
> >
|
||
> > > Does SQL'99 say anything about this?
|
||
> >
|
||
> > Yes, though, as usual, you have to twist your brain a little to understand
|
||
> > it. My understanding is that for a function call of the form "foo(a, b)"
|
||
> > it goes like this:
|
||
> >
|
||
> > 1. Find all functions named "foo" in the current database. This is the
|
||
> > set of "possibly candidate routines".
|
||
> >
|
||
> > 2. Drop all routines that you do not have EXECUTE privilege for. This is
|
||
> > the set of "executable routines".
|
||
> >
|
||
> > 3. Drop all routines that do not have compatible parameter lists. This is
|
||
> > the set of "invocable routines".
|
||
> >
|
||
> > 4. Drop all routines whose schema is not in the path. This is the set of
|
||
> > "candidate routines".
|
||
> >
|
||
> > 5. If you have more than one routine left, eliminate some routines
|
||
> > according to type precedence rules. (We do some form of this, SQL99
|
||
> > specifies something different.) This yields the set of "candidate subject
|
||
> > routines".
|
||
> >
|
||
> > 6. Choose the routine whose schema is earliest in the path as the "subject
|
||
> > routine".
|
||
> >
|
||
> > Execute the subject routine. Phew!
|
||
> >
|
||
> > This doesn't look glaringly wrong to me, so maybe you want to consider it.
|
||
> > Please note step 2.
|
||
> >
|
||
> > --
|
||
> > Peter Eisentraut peter_e@gmx.net
|
||
>
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18257=candle.pha.pa.us=pgman@postgresql.org Tue Jan 29 01:14:41 2002
|
||
Return-path: <pgsql-hackers-owner+M18257=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0T6Eee16404
|
||
for <pgman@candle.pha.pa.us>; Tue, 29 Jan 2002 01:14:40 -0500 (EST)
|
||
Received: (qmail 64203 invoked by alias); 29 Jan 2002 06:14:43 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 29 Jan 2002 06:14:43 -0000
|
||
Received: from sd.tpf.co.jp (sd.tpf.co.jp [210.161.239.34])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0T5lJl60013
|
||
for <pgsql-hackers@postgreSQL.org>; Tue, 29 Jan 2002 00:47:20 -0500 (EST)
|
||
(envelope-from Inoue@tpf.co.jp)
|
||
Received: (qmail 19665 invoked from network); 29 Jan 2002 05:47:24 -0000
|
||
Received: from unknown (HELO viscomail.tpf.co.jp) (100.0.0.108)
|
||
by sd2.tpf-fw-c.co.jp with SMTP; 29 Jan 2002 05:47:24 -0000
|
||
Received: from tpf.co.jp (3dgateway1 [126.0.1.60])
|
||
by viscomail.tpf.co.jp (8.8.8+Sun/8.8.8) with ESMTP id OAA07250;
|
||
Tue, 29 Jan 2002 14:47:22 +0900 (JST)
|
||
Message-ID: <3C56376C.BCA5B3A5@tpf.co.jp>
|
||
Date: Tue, 29 Jan 2002 14:47:24 +0900
|
||
From: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
X-Mailer: Mozilla 4.73 [ja] (Windows NT 5.0; U)
|
||
X-Accept-Language: ja
|
||
MIME-Version: 1.0
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, Tom Lane <tgl@sss.pgh.pa.us>,
|
||
Stephan Szabo <sszabo@megazone23.bigpanda.com>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.NEB.4.33.0201281624010.18868-100000@vespasia.home-net.internetconnect.net>
|
||
Content-Type: text/plain; charset=iso-2022-jp
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Bill Studenmund wrote:
|
||
>
|
||
> On Mon, 28 Jan 2002, Hiroshi Inoue wrote:
|
||
>
|
||
> > Is *the path* below the same as "search path* in other
|
||
> > postings about this thread ?
|
||
>
|
||
> I think so. I believe the path I've been talking about is the one in step
|
||
> 6 below.
|
||
|
||
What I can find in SQL99 is SQL-path.
|
||
Does *the path*(i.e search path) mean SQL-path ?
|
||
They don't seem the same to me.
|
||
|
||
regards,
|
||
Hiroshi Inoue
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18271=candle.pha.pa.us=pgman@postgresql.org Tue Jan 29 12:55:04 2002
|
||
Return-path: <pgsql-hackers-owner+M18271=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0THt2P00626
|
||
for <pgman@candle.pha.pa.us>; Tue, 29 Jan 2002 12:55:02 -0500 (EST)
|
||
Received: (qmail 77793 invoked by alias); 29 Jan 2002 17:54:57 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 29 Jan 2002 17:54:57 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0THmBl76965
|
||
for <pgsql-hackers@postgreSQL.org>; Tue, 29 Jan 2002 12:48:11 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 23554 invoked by uid 1130); 29 Jan 2002 17:48:16 -0000
|
||
Date: Tue, 29 Jan 2002 09:43:22 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, Tom Lane <tgl@sss.pgh.pa.us>,
|
||
Stephan Szabo <sszabo@megazone23.bigpanda.com>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C56376C.BCA5B3A5@tpf.co.jp>
|
||
Message-ID: <Pine.NEB.4.33.0201290939350.24201-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Tue, 29 Jan 2002, Hiroshi Inoue wrote:
|
||
|
||
> Bill Studenmund wrote:
|
||
> >
|
||
> > On Mon, 28 Jan 2002, Hiroshi Inoue wrote:
|
||
> >
|
||
> > > Is *the path* below the same as "search path* in other
|
||
> > > postings about this thread ?
|
||
> >
|
||
> > I think so. I believe the path I've been talking about is the one in step
|
||
> > 6 below.
|
||
>
|
||
> What I can find in SQL99 is SQL-path.
|
||
> Does *the path*(i.e search path) mean SQL-path ?
|
||
> They don't seem the same to me.
|
||
|
||
While we may have not been using the terminology of the spec, I think we
|
||
have been talking about schema paths from SQL99.
|
||
|
||
One difference between our discussions and SQL99 I've noticed is that
|
||
we've spoken of having the path find functions (and operators and
|
||
aggregates), types, _and_tables_. SQL99 doesn't have tables in there
|
||
AFAICT, but I think it makes sense.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18273=candle.pha.pa.us=pgman@postgresql.org Tue Jan 29 19:25:30 2002
|
||
Return-path: <pgsql-hackers-owner+M18273=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0U0PUP06467
|
||
for <pgman@candle.pha.pa.us>; Tue, 29 Jan 2002 19:25:30 -0500 (EST)
|
||
Received: (qmail 92158 invoked by alias); 30 Jan 2002 00:25:29 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 30 Jan 2002 00:25:29 -0000
|
||
Received: from sd.tpf.co.jp (sd.tpf.co.jp [210.161.239.34])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0U0Kil91336
|
||
for <pgsql-hackers@postgreSQL.org>; Tue, 29 Jan 2002 19:20:45 -0500 (EST)
|
||
(envelope-from Inoue@tpf.co.jp)
|
||
Received: (qmail 18978 invoked from network); 30 Jan 2002 00:20:46 -0000
|
||
Received: from unknown (HELO viscomail.tpf.co.jp) (100.0.0.108)
|
||
by sd2.tpf-fw-c.co.jp with SMTP; 30 Jan 2002 00:20:46 -0000
|
||
Received: from tpf.co.jp (3dgateway1 [126.0.1.60])
|
||
by viscomail.tpf.co.jp (8.8.8+Sun/8.8.8) with ESMTP id JAA08622;
|
||
Wed, 30 Jan 2002 09:20:44 +0900 (JST)
|
||
Message-ID: <3C573C5E.F01B48C2@tpf.co.jp>
|
||
Date: Wed, 30 Jan 2002 09:20:46 +0900
|
||
From: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
X-Mailer: Mozilla 4.73 [ja] (Windows NT 5.0; U)
|
||
X-Accept-Language: ja
|
||
MIME-Version: 1.0
|
||
To: Bill Studenmund <wrstuden@netbsd.org>, Peter Eisentraut <peter_e@gmx.net>,
|
||
Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.NEB.4.33.0201290939350.24201-100000@vespasia.home-net.internetconnect.net>
|
||
Content-Type: text/plain; charset=iso-2022-jp
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Bill Studenmund wrote:
|
||
>
|
||
> On Tue, 29 Jan 2002, Hiroshi Inoue wrote:
|
||
>
|
||
> > What I can find in SQL99 is SQL-path.
|
||
> > Does *the path*(i.e search path) mean SQL-path ?
|
||
> > They don't seem the same to me.
|
||
>
|
||
> While we may have not been using the terminology of the spec, I think we
|
||
> have been talking about schema paths from SQL99.
|
||
>
|
||
> One difference between our discussions and SQL99 I've noticed is that
|
||
> we've spoken of having the path find functions (and operators and
|
||
> aggregates), types, _and_tables_.
|
||
|
||
My understanding is the same.
|
||
Tom, Peter is it right ?
|
||
|
||
> SQL99 doesn't have tables in there
|
||
> AFAICT, but I think it makes sense.
|
||
|
||
It seems to make sense but they are different and
|
||
our *path* is never an extension of SQL-path.
|
||
Where are the difference or the relevance referred
|
||
to in this thread ?
|
||
|
||
regards,
|
||
Hiroshi Inoue
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18305=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 15:15:26 2002
|
||
Return-path: <pgsql-hackers-owner+M18305=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0UKFOP11825
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 15:15:25 -0500 (EST)
|
||
Received: (qmail 72977 invoked by alias); 30 Jan 2002 20:15:22 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 30 Jan 2002 20:15:22 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0UKEKl72120
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 30 Jan 2002 15:14:20 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 23890 invoked by uid 1130); 30 Jan 2002 20:13:52 -0000
|
||
Date: Wed, 30 Jan 2002 12:08:54 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, Tom Lane <tgl@sss.pgh.pa.us>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C573C5E.F01B48C2@tpf.co.jp>
|
||
Message-ID: <Pine.NEB.4.33.0201301207540.26920-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 30 Jan 2002, Hiroshi Inoue wrote:
|
||
|
||
> Bill Studenmund wrote:
|
||
> >
|
||
> > On Tue, 29 Jan 2002, Hiroshi Inoue wrote:
|
||
> > SQL99 doesn't have tables in there
|
||
> > AFAICT, but I think it makes sense.
|
||
>
|
||
> It seems to make sense but they are different and
|
||
> our *path* is never an extension of SQL-path.
|
||
> Where are the difference or the relevance referred
|
||
> to in this thread ?
|
||
|
||
How is our path not an extention of SQL-path? Or at least how is the path
|
||
I've been pushing not an SQL-path?
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18307=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 16:15:23 2002
|
||
Return-path: <pgsql-hackers-owner+M18307=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0ULFMP19850
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 16:15:22 -0500 (EST)
|
||
Received: (qmail 96622 invoked by alias); 30 Jan 2002 21:15:08 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 30 Jan 2002 21:15:08 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0ULD4l95438
|
||
for <pgsql-hackers@postgresql.org>; Wed, 30 Jan 2002 16:13:04 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0ULCPf26128;
|
||
Wed, 30 Jan 2002 16:12:25 -0500 (EST)
|
||
To: Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, Peter Eisentraut <peter_e@gmx.net>,
|
||
pgsql-hackers@postgresql.org, Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <20020123162426.K22713-100000@megazone23.bigpanda.com>
|
||
References: <20020123162426.K22713-100000@megazone23.bigpanda.com>
|
||
Comments: In-reply-to Stephan Szabo <sszabo@megazone23.bigpanda.com>
|
||
message dated "Wed, 23 Jan 2002 16:34:32 -0800"
|
||
Date: Wed, 30 Jan 2002 16:12:24 -0500
|
||
Message-ID: <26125.1012425144@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
[ just catching up on this thread after a couple days thinking about
|
||
other things ]
|
||
|
||
Stephan Szabo <sszabo@megazone23.bigpanda.com> writes:
|
||
> AFAIK there's no way to specify that I want to make the function
|
||
> complex(integer) such that I can do CAST(1 as complex) but not as an
|
||
> implicit cast.
|
||
|
||
You may have forgotten that I recently suggested adding just such a
|
||
feature, ie a boolean flag on pg_proc rows to indicate whether they can
|
||
be considered for implicit casts. I think we'd agreed that it would be
|
||
a good thing to do in 7.3.
|
||
|
||
However, that doesn't bear very much on the general argument of the
|
||
thread. The bottom line is that we've put a whole lot of sweat into
|
||
developing rules for resolving ambiguous operator and function calls,
|
||
and I don't think we're going to be willing to toss all that effort into
|
||
the scrap heap. But making namespace search order the dominant factor
|
||
in choosing a function/operator (as Bill seems to want) would certainly
|
||
break all that carefully-crafted effort. If we put the system namespace
|
||
at the front of the search list then users would be unable to override
|
||
standard operators with schema-local substitutes; clearly that's no
|
||
good. But if we put it at the back, then a schema-local user operator
|
||
would dominate all system entries of the same operator name, even for
|
||
quite different types, and thereby it would break the resolution
|
||
behavior.
|
||
|
||
So I'm still of the opinion that my original suggestion is the only
|
||
workable one: collect candidates across all available namespaces,
|
||
discarding only those that are exact matches to candidates in earlier
|
||
namespaces, and then apply the existing resolution rules to the
|
||
collection. AFAICS this need not be any slower than what we do now,
|
||
if the catalog is set up so that we can collect candidates in one
|
||
indexscan without regard to namespace. The case where there actually
|
||
are any exact matches to discard should be uncommon, so we can deal with
|
||
it later on in the resolution process.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|
||
From pgsql-hackers-owner+M18308=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 16:25:39 2002
|
||
Return-path: <pgsql-hackers-owner+M18308=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0ULPcP20879
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 16:25:38 -0500 (EST)
|
||
Received: (qmail 3172 invoked by alias); 30 Jan 2002 21:25:37 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 30 Jan 2002 21:25:37 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0ULM4l01963
|
||
for <pgsql-hackers@postgresql.org>; Wed, 30 Jan 2002 16:22:04 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 21064 invoked by uid 1130); 30 Jan 2002 21:22:04 -0000
|
||
Date: Wed, 30 Jan 2002 13:17:07 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Stephan Szabo <sszabo@megazone23.bigpanda.com>,
|
||
Peter Eisentraut <peter_e@gmx.net>, <pgsql-hackers@postgresql.org>,
|
||
Fernando Nasser <fnasser@redhat.com>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <26125.1012425144@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201301311020.26920-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 30 Jan 2002, Tom Lane wrote:
|
||
|
||
> [ just catching up on this thread after a couple days thinking about
|
||
> other things ]
|
||
>
|
||
> However, that doesn't bear very much on the general argument of the
|
||
> thread. The bottom line is that we've put a whole lot of sweat into
|
||
> developing rules for resolving ambiguous operator and function calls,
|
||
> and I don't think we're going to be willing to toss all that effort into
|
||
> the scrap heap. But making namespace search order the dominant factor
|
||
> in choosing a function/operator (as Bill seems to want) would certainly
|
||
> break all that carefully-crafted effort. If we put the system namespace
|
||
> at the front of the search list then users would be unable to override
|
||
> standard operators with schema-local substitutes; clearly that's no
|
||
> good. But if we put it at the back, then a schema-local user operator
|
||
> would dominate all system entries of the same operator name, even for
|
||
> quite different types, and thereby it would break the resolution
|
||
> behavior.
|
||
|
||
I've changed my mind. :-)
|
||
|
||
> So I'm still of the opinion that my original suggestion is the only
|
||
> workable one: collect candidates across all available namespaces,
|
||
> discarding only those that are exact matches to candidates in earlier
|
||
> namespaces, and then apply the existing resolution rules to the
|
||
> collection. AFAICS this need not be any slower than what we do now,
|
||
> if the catalog is set up so that we can collect candidates in one
|
||
> indexscan without regard to namespace. The case where there actually
|
||
> are any exact matches to discard should be uncommon, so we can deal with
|
||
> it later on in the resolution process.
|
||
|
||
Sounds like the thing to do, and it matches the spec. :-)
|
||
|
||
Oh, you can make a path with your namespace before the built-in one. It's
|
||
just that if you don't include the built-in one (IMPLIMENTATION_SCHEMA) in
|
||
a path, you're supposed to prepend it to the specified list.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18311=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 18:15:49 2002
|
||
Return-path: <pgsql-hackers-owner+M18311=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0UNFmP04299
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 18:15:48 -0500 (EST)
|
||
Received: (qmail 40895 invoked by alias); 30 Jan 2002 23:15:47 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 30 Jan 2002 23:15:47 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0UNDrl39795
|
||
for <pgsql-hackers@postgresql.org>; Wed, 30 Jan 2002 18:13:53 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0UND7f27530;
|
||
Wed, 30 Jan 2002 18:13:07 -0500 (EST)
|
||
To: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C573C5E.F01B48C2@tpf.co.jp>
|
||
References: <Pine.NEB.4.33.0201290939350.24201-100000@vespasia.home-net.internetconnect.net> <3C573C5E.F01B48C2@tpf.co.jp>
|
||
Comments: In-reply-to Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
message dated "Wed, 30 Jan 2002 09:20:46 +0900"
|
||
Date: Wed, 30 Jan 2002 18:13:06 -0500
|
||
Message-ID: <27527.1012432386@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> Bill Studenmund wrote:
|
||
>> While we may have not been using the terminology of the spec, I think we
|
||
>> have been talking about schema paths from SQL99.
|
||
>>
|
||
>> One difference between our discussions and SQL99 I've noticed is that
|
||
>> we've spoken of having the path find functions (and operators and
|
||
>> aggregates), types, _and_tables_.
|
||
|
||
> My understanding is the same.
|
||
> Tom, Peter is it right ?
|
||
|
||
SQL99's SQL-path is very clearly stated to be used only for looking up
|
||
routines and user-defined type names. Extending it to cover tables,
|
||
operators, and so forth makes sense to me, but we have to recognize
|
||
that it is a spec extension and therefore not all the answers we need
|
||
can be found in the spec.
|
||
|
||
I also find it curious that they exclude standard type names from the
|
||
search path. It would seem obvious to treat the standard type names
|
||
as included in a schema that is part of the search path, but AFAICT
|
||
this is not done in the spec. Postgres *has to* do it that way,
|
||
however, or give up our whole approach to datatypes; surely we don't
|
||
want to hardwire the SQL-standard datatypes into the parser to the
|
||
exclusion of the not-so-standard ones.
|
||
|
||
IMHO, the spec's artificial distinction between system and user types
|
||
limits its usefulness as a guide to the questions we're debating here.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 5: Have you checked our extensive FAQ?
|
||
|
||
http://www.postgresql.org/users-lounge/docs/faq.html
|
||
|
||
From pgsql-hackers-owner+M18312=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 18:55:30 2002
|
||
Return-path: <pgsql-hackers-owner+M18312=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0UNtSP08482
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 18:55:29 -0500 (EST)
|
||
Received: (qmail 58399 invoked by alias); 30 Jan 2002 23:55:26 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 30 Jan 2002 23:55:26 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0UNqhl56957
|
||
for <pgsql-hackers@postgresql.org>; Wed, 30 Jan 2002 18:52:43 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 17164 invoked by uid 1130); 30 Jan 2002 23:46:06 -0000
|
||
Date: Wed, 30 Jan 2002 15:41:09 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Hiroshi Inoue <Inoue@tpf.co.jp>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <27527.1012432386@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201301529010.26920-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 30 Jan 2002, Tom Lane wrote:
|
||
|
||
> Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> > Bill Studenmund wrote:
|
||
> >> While we may have not been using the terminology of the spec, I think we
|
||
> >> have been talking about schema paths from SQL99.
|
||
> >>
|
||
> >> One difference between our discussions and SQL99 I've noticed is that
|
||
> >> we've spoken of having the path find functions (and operators and
|
||
> >> aggregates), types, _and_tables_.
|
||
>
|
||
> > My understanding is the same.
|
||
> > Tom, Peter is it right ?
|
||
>
|
||
> SQL99's SQL-path is very clearly stated to be used only for looking up
|
||
> routines and user-defined type names. Extending it to cover tables,
|
||
> operators, and so forth makes sense to me, but we have to recognize
|
||
> that it is a spec extension and therefore not all the answers we need
|
||
> can be found in the spec.
|
||
|
||
True. I think that extending the path to be used for operators and
|
||
aggregates makes sense as they are special types of function calls. The
|
||
searching for tables might need to be a configurable parameter (defaulting
|
||
to yes), though. I think it makes sense to do, but I can imagine cases
|
||
where apps need to not.
|
||
|
||
> I also find it curious that they exclude standard type names from the
|
||
> search path. It would seem obvious to treat the standard type names
|
||
> as included in a schema that is part of the search path, but AFAICT
|
||
> this is not done in the spec. Postgres *has to* do it that way,
|
||
> however, or give up our whole approach to datatypes; surely we don't
|
||
> want to hardwire the SQL-standard datatypes into the parser to the
|
||
> exclusion of the not-so-standard ones.
|
||
>
|
||
> IMHO, the spec's artificial distinction between system and user types
|
||
> limits its usefulness as a guide to the questions we're debating here.
|
||
|
||
True.
|
||
|
||
Does SQL99 support types as flexable as the ones we do? I know types in
|
||
Oracle are basically special cases of already built-in ones...
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18314=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 19:15:14 2002
|
||
Return-path: <pgsql-hackers-owner+M18314=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0V0FDP11130
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 19:15:14 -0500 (EST)
|
||
Received: (qmail 70218 invoked by alias); 31 Jan 2002 00:15:12 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 00:15:12 -0000
|
||
Received: from sd.tpf.co.jp (sd.tpf.co.jp [210.161.239.34])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0UNtQl58401
|
||
for <pgsql-hackers@postgreSQL.org>; Wed, 30 Jan 2002 18:55:28 -0500 (EST)
|
||
(envelope-from Inoue@tpf.co.jp)
|
||
Received: (qmail 11171 invoked from network); 30 Jan 2002 23:55:24 -0000
|
||
Received: from unknown (HELO viscomail.tpf.co.jp) (100.0.0.108)
|
||
by sd2.tpf-fw-c.co.jp with SMTP; 30 Jan 2002 23:55:24 -0000
|
||
Received: from tpf.co.jp (3dgateway1 [126.0.1.60])
|
||
by viscomail.tpf.co.jp (8.8.8+Sun/8.8.8) with ESMTP id IAA10232;
|
||
Thu, 31 Jan 2002 08:55:17 +0900 (JST)
|
||
Message-ID: <3C5887E8.CE7E569F@tpf.co.jp>
|
||
Date: Thu, 31 Jan 2002 08:55:20 +0900
|
||
From: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
X-Mailer: Mozilla 4.73 [ja] (Windows NT 5.0; U)
|
||
X-Accept-Language: ja
|
||
MIME-Version: 1.0
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Peter Eisentraut <peter_e@gmx.net>, Tom Lane <tgl@sss.pgh.pa.us>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.NEB.4.33.0201301207540.26920-100000@vespasia.home-net.internetconnect.net>
|
||
Content-Type: text/plain; charset=iso-2022-jp
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Bill Studenmund wrote:
|
||
>
|
||
> On Wed, 30 Jan 2002, Hiroshi Inoue wrote:
|
||
>
|
||
> > Bill Studenmund wrote:
|
||
> > >
|
||
> > > On Tue, 29 Jan 2002, Hiroshi Inoue wrote:
|
||
> > > SQL99 doesn't have tables in there
|
||
> > > AFAICT, but I think it makes sense.
|
||
> >
|
||
> > It seems to make sense but they are different and
|
||
> > our *path* is never an extension of SQL-path.
|
||
> > Where are the difference or the relevance referred
|
||
> > to in this thread ?
|
||
>
|
||
> How is our path not an extention of SQL-path? Or at least how is the path
|
||
> I've been pushing not an SQL-path?
|
||
|
||
IMHO _tables_like objects must be guarded from such
|
||
a search mechanism fundamentally. I don't object to
|
||
the use of our *path* but it should be distinguished
|
||
from SQL-path.
|
||
|
||
For example the PATH environment variable is used
|
||
only to search executables not files. Is it
|
||
preferable for *rm a_file* to search all the directory
|
||
in the PATH ? If the purpose is different the different
|
||
*path* is needed of cource.
|
||
|
||
regards,
|
||
Hiroshi Inoue
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18317=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 21:15:26 2002
|
||
Return-path: <pgsql-hackers-owner+M18317=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0V2FPP23342
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 21:15:25 -0500 (EST)
|
||
Received: (qmail 15445 invoked by alias); 31 Jan 2002 02:15:12 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 02:15:12 -0000
|
||
Received: from sd.tpf.co.jp (sd.tpf.co.jp [210.161.239.34])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0V1v1l07129
|
||
for <pgsql-hackers@postgresql.org>; Wed, 30 Jan 2002 20:57:01 -0500 (EST)
|
||
(envelope-from Inoue@tpf.co.jp)
|
||
Received: (qmail 21526 invoked from network); 31 Jan 2002 01:57:03 -0000
|
||
Received: from unknown (HELO viscomail.tpf.co.jp) (100.0.0.108)
|
||
by sd2.tpf-fw-c.co.jp with SMTP; 31 Jan 2002 01:57:03 -0000
|
||
Received: from tpf.co.jp (3dgateway1 [126.0.1.60])
|
||
by viscomail.tpf.co.jp (8.8.8+Sun/8.8.8) with ESMTP id KAA10366;
|
||
Thu, 31 Jan 2002 10:57:02 +0900 (JST)
|
||
Message-ID: <3C58A472.2E90C21C@tpf.co.jp>
|
||
Date: Thu, 31 Jan 2002 10:57:06 +0900
|
||
From: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
X-Mailer: Mozilla 4.73 [ja] (Windows NT 5.0; U)
|
||
X-Accept-Language: ja
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.NEB.4.33.0201290939350.24201-100000@vespasia.home-net.internetconnect.net> <3C573C5E.F01B48C2@tpf.co.jp> <27527.1012432386@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=iso-2022-jp
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> > Bill Studenmund wrote:
|
||
> >> While we may have not been using the terminology of the spec, I think we
|
||
> >> have been talking about schema paths from SQL99.
|
||
> >>
|
||
> >> One difference between our discussions and SQL99 I've noticed is that
|
||
> >> we've spoken of having the path find functions (and operators and
|
||
> >> aggregates), types, _and_tables_.
|
||
>
|
||
> > My understanding is the same.
|
||
> > Tom, Peter is it right ?
|
||
>
|
||
> SQL99's SQL-path is very clearly stated to be used only for looking up
|
||
> routines and user-defined type names. Extending it to cover tables,
|
||
> operators, and so forth makes sense to me,
|
||
|
||
I have no objection to the point it makes sense to use
|
||
such *path*s internally but I think it also has a siginificance
|
||
for SQL-path to not look up _tables_like objects.
|
||
I think they are different from the first and we should(need)
|
||
not manage the system with one *path*.
|
||
|
||
BTW I see few references to *catalog*. Would the concept
|
||
of catalog be introduced together. If so what would be
|
||
contained in the current database.
|
||
|
||
regards,
|
||
Hiroshi Inoue
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18319=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 21:45:37 2002
|
||
Return-path: <pgsql-hackers-owner+M18319=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0V2jZP27049
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 21:45:36 -0500 (EST)
|
||
Received: (qmail 27626 invoked by alias); 31 Jan 2002 02:45:32 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 02:45:32 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0V2Wfl22316
|
||
for <pgsql-hackers@postgresql.org>; Wed, 30 Jan 2002 21:32:41 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0V2WAf29271;
|
||
Wed, 30 Jan 2002 21:32:10 -0500 (EST)
|
||
To: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C58A472.2E90C21C@tpf.co.jp>
|
||
References: <Pine.NEB.4.33.0201290939350.24201-100000@vespasia.home-net.internetconnect.net> <3C573C5E.F01B48C2@tpf.co.jp> <27527.1012432386@sss.pgh.pa.us> <3C58A472.2E90C21C@tpf.co.jp>
|
||
Comments: In-reply-to Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
message dated "Thu, 31 Jan 2002 10:57:06 +0900"
|
||
Date: Wed, 30 Jan 2002 21:32:10 -0500
|
||
Message-ID: <29268.1012444330@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> I have no objection to the point it makes sense to use
|
||
> such *path*s internally but I think it also has a siginificance
|
||
> for SQL-path to not look up _tables_like objects.
|
||
> I think they are different from the first and we should(need)
|
||
> not manage the system with one *path*.
|
||
|
||
I'm unconvinced. We must search for datatypes and tables on the same
|
||
path because tables have associated datatypes; it will definitely not
|
||
do to look for a table's datatype and get the wrong type. And I think
|
||
that functions and operators should be looked for on the same path
|
||
as datatypes, because a type should be pretty closely associated with
|
||
the functions/operators for it. So it seems to me that the apparent
|
||
flexibility of having more than one path is just a way to shoot yourself
|
||
in the foot. Why are you concerned that we keep them separate?
|
||
|
||
> BTW I see few references to *catalog*. Would the concept
|
||
> of catalog be introduced together. If so what would be
|
||
> contained in the current database.
|
||
|
||
My thought is that we will consider catalog == database. As far as
|
||
I can tell, that is a legitimate implementation-defined way of
|
||
interpreting the spec. (It's not clear to me what the value is of
|
||
having more than one level of schema hierarchy; or at least, if you want
|
||
hierarchical namespaces, there's no argument for stopping at depth two.
|
||
But I digress.) To satisfy the spec we must allow a (purely decorative)
|
||
specification of the current database name as the catalog level of a
|
||
qualified name, but that's as far as I want to go. In this round,
|
||
anyway. Cross-database access is not something to tackle for 7.3.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18323=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 22:45:10 2002
|
||
Return-path: <pgsql-hackers-owner+M18323=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0V3j9P04896
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 22:45:09 -0500 (EST)
|
||
Received: (qmail 48073 invoked by alias); 31 Jan 2002 03:45:06 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 03:45:06 -0000
|
||
Received: from sd.tpf.co.jp (sd.tpf.co.jp [210.161.239.34])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0V3aPl45009
|
||
for <pgsql-hackers@postgresql.org>; Wed, 30 Jan 2002 22:36:27 -0500 (EST)
|
||
(envelope-from Inoue@tpf.co.jp)
|
||
Received: (qmail 31045 invoked from network); 31 Jan 2002 03:36:21 -0000
|
||
Received: from unknown (HELO viscomail.tpf.co.jp) (100.0.0.108)
|
||
by sd2.tpf-fw-c.co.jp with SMTP; 31 Jan 2002 03:36:21 -0000
|
||
Received: from tpf.co.jp (3dgateway1 [126.0.1.60])
|
||
by viscomail.tpf.co.jp (8.8.8+Sun/8.8.8) with ESMTP id MAA10485;
|
||
Thu, 31 Jan 2002 12:36:15 +0900 (JST)
|
||
Message-ID: <3C58BBB3.58D5F964@tpf.co.jp>
|
||
Date: Thu, 31 Jan 2002 12:36:19 +0900
|
||
From: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
X-Mailer: Mozilla 4.73 [ja] (Windows NT 5.0; U)
|
||
X-Accept-Language: ja
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.NEB.4.33.0201290939350.24201-100000@vespasia.home-net.internetconnect.net> <3C573C5E.F01B48C2@tpf.co.jp> <27527.1012432386@sss.pgh.pa.us> <3C58A472.2E90C21C@tpf.co.jp> <29268.1012444330@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=iso-2022-jp
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> > I have no objection to the point it makes sense to use
|
||
> > such *path*s internally but I think it also has a siginificance
|
||
> > for SQL-path to not look up _tables_like objects.
|
||
> > I think they are different from the first and we should(need)
|
||
> > not manage the system with one *path*.
|
||
>
|
||
> I'm unconvinced. We must search for datatypes and tables on the same
|
||
> path because tables have associated datatypes;
|
||
|
||
Isn't the table definition a part of the datatype in
|
||
such a case ?
|
||
|
||
> it will definitely not
|
||
> do to look for a table's datatype and get the wrong type. And I think
|
||
> that functions and operators should be looked for on the same path
|
||
> as datatypes, because a type should be pretty closely associated with
|
||
> the functions/operators for it. So it seems to me that the apparent
|
||
> flexibility of having more than one path is just a way to shoot yourself
|
||
> in the foot. Why are you concerned that we keep them separate?
|
||
|
||
For example, doesn't 'DROP table a_table' drop the
|
||
a_table table in a schema in the *path* if there's
|
||
no a_table table in the current schema ?
|
||
|
||
If we would never introduce SQL-paths (in the future)
|
||
there would be problem.
|
||
|
||
regards,
|
||
Hiroshi Inoue
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 2: you can get off all lists at once with the unregister command
|
||
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)
|
||
|
||
From pgsql-hackers-owner+M18325=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 22:55:24 2002
|
||
Return-path: <pgsql-hackers-owner+M18325=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0V3tOP06352
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 22:55:24 -0500 (EST)
|
||
Received: (qmail 52777 invoked by alias); 31 Jan 2002 03:55:21 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 03:55:21 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0V3iml47386
|
||
for <pgsql-hackers@postgresql.org>; Wed, 30 Jan 2002 22:44:48 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0V3hff29736;
|
||
Wed, 30 Jan 2002 22:43:42 -0500 (EST)
|
||
To: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C58BBB3.58D5F964@tpf.co.jp>
|
||
References: <Pine.NEB.4.33.0201290939350.24201-100000@vespasia.home-net.internetconnect.net> <3C573C5E.F01B48C2@tpf.co.jp> <27527.1012432386@sss.pgh.pa.us> <3C58A472.2E90C21C@tpf.co.jp> <29268.1012444330@sss.pgh.pa.us> <3C58BBB3.58D5F964@tpf.co.jp>
|
||
Comments: In-reply-to Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
message dated "Thu, 31 Jan 2002 12:36:19 +0900"
|
||
Date: Wed, 30 Jan 2002 22:43:41 -0500
|
||
Message-ID: <29733.1012448621@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> For example, doesn't 'DROP table a_table' drop the
|
||
> a_table table in a schema in the *path* if there's
|
||
> no a_table table in the current schema ?
|
||
|
||
Sure. And that's exactly what it should do, IMHO.
|
||
Otherwise the notion that you can ignore your private
|
||
schema (at the front of the path) if you're not using
|
||
it falls down. Also, we wouldn't be able to implement
|
||
temp tables via a backend-local schema at the front of
|
||
the path.
|
||
|
||
Any security concerns here should be addressed by putting
|
||
ACLs on the schemas you don't want altered; not by contorting
|
||
the notion of a search path to work for some operations and
|
||
not others.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18326=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 23:15:07 2002
|
||
Return-path: <pgsql-hackers-owner+M18326=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0V4F6P09920
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 23:15:06 -0500 (EST)
|
||
Received: (qmail 57935 invoked by alias); 31 Jan 2002 04:15:03 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 04:15:03 -0000
|
||
Received: from sd.tpf.co.jp (sd.tpf.co.jp [210.161.239.34])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0V3lIl50338
|
||
for <pgsql-hackers@postgresql.org>; Wed, 30 Jan 2002 22:47:20 -0500 (EST)
|
||
(envelope-from Inoue@tpf.co.jp)
|
||
Received: (qmail 31967 invoked from network); 31 Jan 2002 03:47:17 -0000
|
||
Received: from unknown (HELO viscomail.tpf.co.jp) (100.0.0.108)
|
||
by sd2.tpf-fw-c.co.jp with SMTP; 31 Jan 2002 03:47:17 -0000
|
||
Received: from tpf.co.jp (3dgateway1 [126.0.1.60])
|
||
by viscomail.tpf.co.jp (8.8.8+Sun/8.8.8) with ESMTP id MAA10500;
|
||
Thu, 31 Jan 2002 12:47:17 +0900 (JST)
|
||
Message-ID: <3C58BE48.AD4EE527@tpf.co.jp>
|
||
Date: Thu, 31 Jan 2002 12:47:20 +0900
|
||
From: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
X-Mailer: Mozilla 4.73 [ja] (Windows NT 5.0; U)
|
||
X-Accept-Language: ja
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.NEB.4.33.0201290939350.24201-100000@vespasia.home-net.internetconnect.net> <3C573C5E.F01B48C2@tpf.co.jp> <27527.1012432386@sss.pgh.pa.us> <3C58A472.2E90C21C@tpf.co.jp> <29268.1012444330@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=iso-2022-jp
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
>
|
||
> > BTW I see few references to *catalog*. Would the concept
|
||
> > of catalog be introduced together. If so what would be
|
||
> > contained in the current database.
|
||
>
|
||
> My thought is that we will consider catalog == database. As far as
|
||
> I can tell, that is a legitimate implementation-defined way of
|
||
> interpreting the spec. (It's not clear to me what the value is of
|
||
> having more than one level of schema hierarchy; or at least, if you want
|
||
> hierarchical namespaces, there's no argument for stopping at depth two.
|
||
> But I digress.) To satisfy the spec we must allow a (purely decorative)
|
||
> specification of the current database name as the catalog level of a
|
||
> qualified name, but that's as far as I want to go. In this round,
|
||
> anyway. Cross-database access is not something to tackle for 7.3.
|
||
|
||
Just a confirmation.
|
||
We can't see any catalog.schema.object notation in 7.3,
|
||
can we ?
|
||
|
||
regards,
|
||
Hiroshi Inoue
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18324=candle.pha.pa.us=pgman@postgresql.org Wed Jan 30 22:55:24 2002
|
||
Return-path: <pgsql-hackers-owner+M18324=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0V3tOP06351
|
||
for <pgman@candle.pha.pa.us>; Wed, 30 Jan 2002 22:55:24 -0500 (EST)
|
||
Received: (qmail 52747 invoked by alias); 31 Jan 2002 03:55:20 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 03:55:20 -0000
|
||
Received: from sss.pgh.pa.us ([192.204.191.242])
|
||
by postgresql.org (8.11.3/8.11.4) with ESMTP id g0V3pTl51655
|
||
for <pgsql-hackers@postgresql.org>; Wed, 30 Jan 2002 22:51:29 -0500 (EST)
|
||
(envelope-from tgl@sss.pgh.pa.us)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss.pgh.pa.us (8.11.4/8.11.4) with ESMTP id g0V3p0f29810;
|
||
Wed, 30 Jan 2002 22:51:00 -0500 (EST)
|
||
To: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C58BE48.AD4EE527@tpf.co.jp>
|
||
References: <Pine.NEB.4.33.0201290939350.24201-100000@vespasia.home-net.internetconnect.net> <3C573C5E.F01B48C2@tpf.co.jp> <27527.1012432386@sss.pgh.pa.us> <3C58A472.2E90C21C@tpf.co.jp> <29268.1012444330@sss.pgh.pa.us> <3C58BE48.AD4EE527@tpf.co.jp>
|
||
Comments: In-reply-to Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
message dated "Thu, 31 Jan 2002 12:47:20 +0900"
|
||
Date: Wed, 30 Jan 2002 22:51:00 -0500
|
||
Message-ID: <29807.1012449060@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> Just a confirmation.
|
||
> We can't see any catalog.schema.object notation in 7.3,
|
||
> can we ?
|
||
|
||
No, what I meant was you could write catalog.schema.object --- but for
|
||
7.3, the system will only accept it if the catalog name is the same as
|
||
the current database. This satisfies the minimum requirements of the
|
||
spec, and it leaves notational room to use the catalog name as the cue
|
||
for cross-database access, if we ever decide we want to try to do that.
|
||
|
||
regards, tom lane
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18334=candle.pha.pa.us=pgman@postgresql.org Thu Jan 31 05:45:28 2002
|
||
Return-path: <pgsql-hackers-owner+M18334=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0VAjRP11000
|
||
for <pgman@candle.pha.pa.us>; Thu, 31 Jan 2002 05:45:27 -0500 (EST)
|
||
Received: (qmail 4065 invoked by alias); 31 Jan 2002 10:45:25 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 10:45:25 -0000
|
||
Received: from sd.tpf.co.jp (sd.tpf.co.jp [210.161.239.34])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0VAbGl02141
|
||
for <pgsql-hackers@postgresql.org>; Thu, 31 Jan 2002 05:37:17 -0500 (EST)
|
||
(envelope-from Inoue@tpf.co.jp)
|
||
Received: (qmail 30401 invoked from network); 31 Jan 2002 10:37:17 -0000
|
||
Received: from unknown (HELO viscomail.tpf.co.jp) (100.0.0.108)
|
||
by sd2.tpf-fw-c.co.jp with SMTP; 31 Jan 2002 10:37:17 -0000
|
||
Received: from tpf.co.jp (3dgateway1 [126.0.1.60])
|
||
by viscomail.tpf.co.jp (8.8.8+Sun/8.8.8) with ESMTP id TAA10891;
|
||
Thu, 31 Jan 2002 19:37:15 +0900 (JST)
|
||
Message-ID: <3C591E5E.14549DF@tpf.co.jp>
|
||
Date: Thu, 31 Jan 2002 19:37:18 +0900
|
||
From: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
X-Mailer: Mozilla 4.73 [ja] (Windows NT 5.0; U)
|
||
X-Accept-Language: ja
|
||
MIME-Version: 1.0
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Bill Studenmund <wrstuden@netbsd.org>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.NEB.4.33.0201290939350.24201-100000@vespasia.home-net.internetconnect.net> <3C573C5E.F01B48C2@tpf.co.jp> <27527.1012432386@sss.pgh.pa.us> <3C58A472.2E90C21C@tpf.co.jp> <29268.1012444330@sss.pgh.pa.us> <3C58BBB3.58D5F964@tpf.co.jp> <29733.1012448621@sss.pgh.pa.us>
|
||
Content-Type: text/plain; charset=iso-2022-jp
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Tom Lane wrote:
|
||
>
|
||
> Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> > For example, doesn't 'DROP table a_table' drop the
|
||
> > a_table table in a schema in the *path* if there's
|
||
> > no a_table table in the current schema ?
|
||
>
|
||
> Sure. And that's exactly what it should do, IMHO.
|
||
> Otherwise the notion that you can ignore your private
|
||
> schema (at the front of the path) if you're not using
|
||
> it falls down. Also, we wouldn't be able to implement
|
||
> temp tables via a backend-local schema at the front of
|
||
> the path.
|
||
|
||
I don't think it's useful for tables other than temp
|
||
ones and I wouldn't use it other than for temp ones.
|
||
|
||
When we type 'rm a_file' in a shell environment
|
||
does the *rm* command search the PATH in finding
|
||
the a_file file ? Even though we need to implement
|
||
such a search mechanism we would use another path
|
||
different from the executable search PATH. I don't
|
||
think our *path* is an extension of SQL-path.
|
||
|
||
I wouldn't complain unless we call the *path*
|
||
as SQL-path or an extension of SQL-path.
|
||
|
||
regards,
|
||
Hiroshi Inoue
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18340=candle.pha.pa.us=pgman@postgresql.org Thu Jan 31 11:55:49 2002
|
||
Return-path: <pgsql-hackers-owner+M18340=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0VGtmP13664
|
||
for <pgman@candle.pha.pa.us>; Thu, 31 Jan 2002 11:55:48 -0500 (EST)
|
||
Received: (qmail 32205 invoked by alias); 31 Jan 2002 16:53:46 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 16:53:46 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0VGVXl24649
|
||
for <pgsql-hackers@postgresql.org>; Thu, 31 Jan 2002 11:31:37 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 29829 invoked by uid 1130); 31 Jan 2002 16:31:38 -0000
|
||
Date: Thu, 31 Jan 2002 08:26:40 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C58A472.2E90C21C@tpf.co.jp>
|
||
Message-ID: <Pine.NEB.4.33.0201310823050.29090-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Thu, 31 Jan 2002, Hiroshi Inoue wrote:
|
||
|
||
> Tom Lane wrote:
|
||
> >
|
||
> > Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> > SQL99's SQL-path is very clearly stated to be used only for looking up
|
||
> > routines and user-defined type names. Extending it to cover tables,
|
||
> > operators, and so forth makes sense to me,
|
||
>
|
||
> I have no objection to the point it makes sense to use
|
||
> such *path*s internally but I think it also has a siginificance
|
||
> for SQL-path to not look up _tables_like objects.
|
||
> I think they are different from the first and we should(need)
|
||
> not manage the system with one *path*.
|
||
|
||
I'm confused. Are you suggesting multiple paths? i.e. a function/type path
|
||
and a table one?
|
||
|
||
I think calling our path an SQL path is fine. Yes, we extend it by using
|
||
it for tables too, but it strikes me as still fundamentally an SQL path.
|
||
So I don't see why we should not call it that.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 6: Have you searched our list archives?
|
||
|
||
http://archives.postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18342=candle.pha.pa.us=pgman@postgresql.org Thu Jan 31 11:56:06 2002
|
||
Return-path: <pgsql-hackers-owner+M18342=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0VGu5P13918
|
||
for <pgman@candle.pha.pa.us>; Thu, 31 Jan 2002 11:56:05 -0500 (EST)
|
||
Received: (qmail 32437 invoked by alias); 31 Jan 2002 16:53:56 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 16:53:56 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0VGdAl25623
|
||
for <pgsql-hackers@postgresql.org>; Thu, 31 Jan 2002 11:39:11 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 29902 invoked by uid 1130); 31 Jan 2002 16:33:09 -0000
|
||
Date: Thu, 31 Jan 2002 08:28:10 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C58BBB3.58D5F964@tpf.co.jp>
|
||
Message-ID: <Pine.NEB.4.33.0201310827380.29090-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Thu, 31 Jan 2002, Hiroshi Inoue wrote:
|
||
|
||
> > it will definitely not
|
||
> > do to look for a table's datatype and get the wrong type. And I think
|
||
> > that functions and operators should be looked for on the same path
|
||
> > as datatypes, because a type should be pretty closely associated with
|
||
> > the functions/operators for it. So it seems to me that the apparent
|
||
> > flexibility of having more than one path is just a way to shoot yourself
|
||
> > in the foot. Why are you concerned that we keep them separate?
|
||
>
|
||
> For example, doesn't 'DROP table a_table' drop the
|
||
> a_table table in a schema in the *path* if there's
|
||
> no a_table table in the current schema ?
|
||
>
|
||
> If we would never introduce SQL-paths (in the future)
|
||
> there would be problem.
|
||
|
||
??
|
||
|
||
We're talking about adding them now. Why would we add them twice?
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18341=candle.pha.pa.us=pgman@postgresql.org Thu Jan 31 11:59:16 2002
|
||
Return-path: <pgsql-hackers-owner+M18341=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0VGxFP14456
|
||
for <pgman@candle.pha.pa.us>; Thu, 31 Jan 2002 11:59:15 -0500 (EST)
|
||
Received: (qmail 32440 invoked by alias); 31 Jan 2002 16:53:56 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 16:53:56 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0VGdAl25618
|
||
for <pgsql-hackers@postgresql.org>; Thu, 31 Jan 2002 11:39:11 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 223 invoked by uid 1130); 31 Jan 2002 16:36:01 -0000
|
||
Date: Thu, 31 Jan 2002 08:31:03 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Tom Lane <tgl@sss.pgh.pa.us>
|
||
cc: Hiroshi Inoue <Inoue@tpf.co.jp>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <29733.1012448621@sss.pgh.pa.us>
|
||
Message-ID: <Pine.NEB.4.33.0201310828190.29090-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Wed, 30 Jan 2002, Tom Lane wrote:
|
||
|
||
> Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> > For example, doesn't 'DROP table a_table' drop the
|
||
> > a_table table in a schema in the *path* if there's
|
||
> > no a_table table in the current schema ?
|
||
>
|
||
> Sure. And that's exactly what it should do, IMHO.
|
||
> Otherwise the notion that you can ignore your private
|
||
> schema (at the front of the path) if you're not using
|
||
> it falls down. Also, we wouldn't be able to implement
|
||
> temp tables via a backend-local schema at the front of
|
||
> the path.
|
||
|
||
Well, I disagree on this one. :-) I'd vote drop should need a specific
|
||
schema if it's not the current one. But I won't push the point. :-)
|
||
|
||
> Any security concerns here should be addressed by putting
|
||
> ACLs on the schemas you don't want altered; not by contorting
|
||
> the notion of a search path to work for some operations and
|
||
> not others.
|
||
|
||
I'm not so concerned about security as being sure of operator intent. ACLs
|
||
address security (and should be used), but they don't address making sure
|
||
you delete exactly what you wanted.
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 1: subscribe and unsubscribe commands go to majordomo@postgresql.org
|
||
|
||
From pgsql-hackers-owner+M18341=candle.pha.pa.us=pgman@postgresql.org Thu Jan 31 12:00:40 2002
|
||
Return-path: <pgsql-hackers-owner+M18341=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g0VH0dP14749
|
||
for <pgman@candle.pha.pa.us>; Thu, 31 Jan 2002 12:00:39 -0500 (EST)
|
||
Received: (qmail 32325 invoked by alias); 31 Jan 2002 16:53:51 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 31 Jan 2002 16:53:51 -0000
|
||
Received: from mail.netbsd.org (mail.netbsd.org [155.53.1.253])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g0VGdAl25625
|
||
for <pgsql-hackers@postgresql.org>; Thu, 31 Jan 2002 11:39:12 -0500 (EST)
|
||
(envelope-from wrstuden@netbsd.org)
|
||
Received: (qmail 284 invoked by uid 1130); 31 Jan 2002 16:38:48 -0000
|
||
Date: Thu, 31 Jan 2002 08:33:50 -0800 (PST)
|
||
From: Bill Studenmund <wrstuden@netbsd.org>
|
||
X-X-Sender: <wrstuden@vespasia.home-net.internetconnect.net>
|
||
To: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
In-Reply-To: <3C591E5E.14549DF@tpf.co.jp>
|
||
Message-ID: <Pine.NEB.4.33.0201310831290.29090-100000@vespasia.home-net.internetconnect.net>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
On Thu, 31 Jan 2002, Hiroshi Inoue wrote:
|
||
|
||
> Tom Lane wrote:
|
||
> >
|
||
> > Hiroshi Inoue <Inoue@tpf.co.jp> writes:
|
||
> > > For example, doesn't 'DROP table a_table' drop the
|
||
> > > a_table table in a schema in the *path* if there's
|
||
> > > no a_table table in the current schema ?
|
||
> >
|
||
> > Sure. And that's exactly what it should do, IMHO.
|
||
> > Otherwise the notion that you can ignore your private
|
||
> > schema (at the front of the path) if you're not using
|
||
> > it falls down. Also, we wouldn't be able to implement
|
||
> > temp tables via a backend-local schema at the front of
|
||
> > the path.
|
||
>
|
||
> I don't think it's useful for tables other than temp
|
||
> ones and I wouldn't use it other than for temp ones.
|
||
|
||
I agree.
|
||
|
||
> When we type 'rm a_file' in a shell environment
|
||
> does the *rm* command search the PATH in finding
|
||
> the a_file file ? Even though we need to implement
|
||
> such a search mechanism we would use another path
|
||
> different from the executable search PATH. I don't
|
||
> think our *path* is an extension of SQL-path.
|
||
>
|
||
> I wouldn't complain unless we call the *path*
|
||
> as SQL-path or an extension of SQL-path.
|
||
|
||
I still don't get this. The path we're talking about is the same thing
|
||
(with the same envirnment name and operational syntax) as SQL-paths,
|
||
except that we use it to find tables too. Why does that make it not an SQL
|
||
path?
|
||
|
||
Take care,
|
||
|
||
Bill
|
||
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 4: Don't 'kill -9' the postmaster
|
||
|
||
From pgsql-hackers-owner+M18346=candle.pha.pa.us=pgman@postgresql.org Thu Jan 31 20:15:10 2002
|
||
Return-path: <pgsql-hackers-owner+M18346=candle.pha.pa.us=pgman@postgresql.org>
|
||
Received: from server1.pgsql.org (www.postgresql.org [64.49.215.9])
|
||
by candle.pha.pa.us (8.11.6/8.10.1) with SMTP id g111FAP04980
|
||
for <pgman@candle.pha.pa.us>; Thu, 31 Jan 2002 20:15:10 -0500 (EST)
|
||
Received: (qmail 48143 invoked by alias); 1 Feb 2002 01:15:08 -0000
|
||
Received: from unknown (HELO postgresql.org) (64.49.215.8)
|
||
by www.postgresql.org with SMTP; 1 Feb 2002 01:15:08 -0000
|
||
Received: from sd.tpf.co.jp (sd.tpf.co.jp [210.161.239.34])
|
||
by postgresql.org (8.11.3/8.11.4) with SMTP id g11181l47339
|
||
for <pgsql-hackers@postgresql.org>; Thu, 31 Jan 2002 20:08:01 -0500 (EST)
|
||
(envelope-from Inoue@tpf.co.jp)
|
||
Received: (qmail 14937 invoked from network); 1 Feb 2002 01:08:03 -0000
|
||
Received: from unknown (HELO viscomail.tpf.co.jp) (100.0.0.108)
|
||
by sd2.tpf-fw-c.co.jp with SMTP; 1 Feb 2002 01:08:03 -0000
|
||
Received: from tpf.co.jp (3dgateway1 [126.0.1.60])
|
||
by viscomail.tpf.co.jp (8.8.8+Sun/8.8.8) with ESMTP id KAA11846;
|
||
Fri, 1 Feb 2002 10:08:01 +0900 (JST)
|
||
Message-ID: <3C59EA75.E117B2FA@tpf.co.jp>
|
||
Date: Fri, 01 Feb 2002 10:08:05 +0900
|
||
From: Hiroshi Inoue <Inoue@tpf.co.jp>
|
||
X-Mailer: Mozilla 4.73 [ja] (Windows NT 5.0; U)
|
||
X-Accept-Language: ja
|
||
MIME-Version: 1.0
|
||
To: Bill Studenmund <wrstuden@netbsd.org>
|
||
cc: Tom Lane <tgl@sss.pgh.pa.us>, Peter Eisentraut <peter_e@gmx.net>,
|
||
PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] RFD: schemas and different kinds of Postgres objects
|
||
References: <Pine.NEB.4.33.0201310831290.29090-100000@vespasia.home-net.internetconnect.net>
|
||
Content-Type: text/plain; charset=iso-2022-jp
|
||
Content-Transfer-Encoding: 7bit
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@postgresql.org
|
||
Status: OR
|
||
|
||
Bill Studenmund wrote:
|
||
>
|
||
> On Thu, 31 Jan 2002, Hiroshi Inoue wrote:
|
||
> >
|
||
> > I wouldn't complain unless we call the *path*
|
||
> > as SQL-path or an extension of SQL-path.
|
||
>
|
||
> I still don't get this. The path we're talking about is the same thing
|
||
> (with the same envirnment name and operational syntax) as SQL-paths,
|
||
> except that we use it to find tables too. Why does that make it not an SQL
|
||
> path?
|
||
|
||
I don't think It's always good to follow the standard.
|
||
However it's very wrong to change the meaning of words
|
||
in the standard. It seems impossible to introduce SQL-path
|
||
using our *path*. The *path* is PostgreSQL specific and
|
||
it would be configurable for us to be SQL99-compatible
|
||
(without SQL-path) or SQL99-imcompatible using the *path*.
|
||
|
||
regards,
|
||
Hiroshi Inoue
|
||
|
||
---------------------------(end of broadcast)---------------------------
|
||
TIP 3: if posting/reading through Usenet, please send an appropriate
|
||
subscribe-nomail command to majordomo@postgresql.org so that your
|
||
message can get through to the mailing list cleanly
|
||
|