From: | Michael Wood <esiotrot(at)gmail(dot)com> |
---|---|
To: | Marcin Krol <mrkafk(at)gmail(dot)com> |
Cc: | pgsql-novice(at)postgresql(dot)org |
Subject: | Re: Special table names |
Date: | 2010-02-26 14:59:22 |
Message-ID: | 5a8aa6681002260659r331219f9u7b3d72e9edcdca2f@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-novice |
On 26 February 2010 15:35, Marcin Krol <mrkafk(at)gmail(dot)com> wrote:
> Michael Wood wrote:
>
>>
>> In addition to what Andreas said, try "\dS" (and "\?").
>
> Thanks, that's useful -- but that still doesn't let me tell where 'user'
> table (view? alias?) comes from.
>
>> You should probably use "CREATE ROLE", "ALTER ROLE", "DROP ROLE" etc.
>> instead of manipulating pg_user directly.
>
> I have no intention to do that; I just created test db via ORM called
> SQLAlchemy, with table named 'user'.
It seems SQLAlchemy lied to you about creating the table, or perhaps
you did not check an error code or something.
blah=> create table user (id int);
ERROR: syntax error at or near "user"
LINE 1: create table user (id int);
^
Note that it says "syntax error" and not "relation already exists".
> Then I drop into psql, do 'select * from user' to see what's in there and I
> don't see what I expected to see:
>
> ts=# \c ts;
>
> ts=# select * from user;
> current_user
> --------------
> postgres
> (1 row)
>
>
> So I'm wondering if there are other special table names I should avoid.
I suppose any function in the list Andreas pointed you at that don't
have parentheses. Also anything called pg_something. Not sure what
else.
--
Michael Wood <esiotrot(at)gmail(dot)com>
From | Date | Subject | |
---|---|---|---|
Next Message | Marcin Krol | 2010-02-26 16:23:52 | Re: Special table names |
Previous Message | Michael Wood | 2010-02-26 14:54:48 | Re: Special table names |