ODBC functions in gram.y - Mailing list pgsql-hackers

From Thomas Lockhart
Subject ODBC functions in gram.y
Date
Msg-id 3C10F1A2.8A6EC580@fourpalms.org
Whole thread Raw
Responses Re: ODBC functions in gram.y

List pgsql-hackers
I'm looking at gram.y to munge the precision support for date/time per
recent discussions, and am noticing once again the extensions added to
support ODBC by allowing empty parens after some SQL-defined "constants"
(e.g. CURRENT_TIMESTAMP, CURRENT_USER, etc etc). Currently, these are
done by replicating code and by altering the allowed grammar, and it
happens to be the same area of code I need to be looking at.

There is are existing mechanisms for supporting ODBC function mappings
and function extensions which do not require altering gram.y. I would
propose that we use these mechanisms for this case.

The mechanisms are:
 1) remap function names in the ODBC driver (odbc/convert.c; trivial). 2) define (some) new functions as SQL functions
(inodbc/odbc.sql;
 
trivial).

The remapped function names from (1) either already exist in PostgreSQL,
or are newly defined in odbc.sql. For the particular cases gram.y was
altered to support, the ODBC function names conflict in our grammar, so
they should be mapped to a non-conflicting name. For example, to support
*ODBC* syntax CURRENT_TIMESTAMP() (illegal in SQL99), we would add a
mapping in convert.c as
 "CURRENT_TIMESTAMP", odbc_timestamp

and then augment odbc.sql to include
 create or replace function odbc_timestamp() returns timestamp as '   select current_timestamp; ' language 'sql';

This can be done with the other half dozen or so functions now in
gram.y.

Comments?
                     - Thomas


pgsql-hackers by date:

Previous
From: Thomas Lockhart
Date:
Subject: Third call for platform testing
Next
From: Thomas Lockhart
Date:
Subject: Re: Third call for platform testing