Thread: case insensitive table names

case insensitive table names

From
alwin
Date:
Dear mailing list,

I'm trying to convert a MsSQL database to a Postgres database, with DTS i can
convert the data between the databases. DTS creates case sensitive tables
(using quotes), exactly like i want it to be.

So far so good. But the current code uses queries without quotes, like
select * from Table; and not select * from "Table";. The Table gets
converted to
lowercase and then compared (case sensitive) against the tables in the
database.

This means i have to convert all the table names to lowercase, losing a lot
of readability,
or i put quotes around all the table names in the current queries causing
also a lot of
possible problems and unneeded changes.

Is there an easier fix for this? Does the SQL92/SQL3/SQL2003 specify
unquoted table
names to be case-insensitive or does it say it needs to be converted to
lowercase?

It would be great having a global flag to enable or disable case sensitive
compares
everywhere.

Thanks.

Alwin




Re: case insensitive table names

From
Tom Lane
Date:
alwin <alwin@cs.nl> writes:
> So far so good. But the current code uses queries without quotes, like
> select * from Table; and not select * from "Table";.

You have a problem :-(

> Is there an easier fix for this? Does the SQL92/SQL3/SQL2003 specify
> unquoted table names to be case-insensitive or does it say it needs to
> be converted to lowercase?

The SQL spec is absolutely clear that the above code is wrong.  What the
spec actually says is that unquoted names should be forced to all upper
case (so Table is equivalent to "TABLE").  Postgres forces them to lower
case (so Table is equivalent to "table") which is not quite the same but
has the same effect that unquoted names are not case sensitive.  But
under both the exact spec rules and our rules, a mixed-case quoted name
is never equivalent to any unquoted name.  There is no such thing as
case insensitivity for quoted names.

            regards, tom lane

unsuscribe

From
David Cancino Muñiz
Date:
unsuscribe