Re: Object IDs in Parse message - Mailing list pgsql-interfaces

From Tom Lane
Subject Re: Object IDs in Parse message
Date
Msg-id 32018.1567542279@sss.pgh.pa.us
Whole thread Raw
In response to Object IDs in Parse message  (Malcolm Matalka <mmatalka@gmail.com>)
Responses Re: Object IDs in Parse message
List pgsql-interfaces
Malcolm Matalka <mmatalka@gmail.com> writes:
> Hello, I'm implementing my own pgsql client for fun and I'm trying to
> understand how to send a Parse message.  The final parameter to Parse is
> a series of Int32s with the description:
> Specifies the object ID of the parameter data type. Placing a zero here
> is equivalent to leaving the type unspecified.

> But where do I find the list of object IDs?

SELECT oid, typname FROM pg_type;

> If so, It's not clear how to express some things.  For example there is
> a MONEYARRAYOID, but no MONEYOID.

For historical reasons, the macro for money's OID is CASHOID.
There's no grandfathered symbol for money[], though, so that
gets a name constructed per standard rules (cf form_pg_type_symbol
in genbki.pl).

However, I fail to see why a generic client would need to know that.
If you're hard-wiring OIDs into your code for anything beyond very
basic types like int4, you're probably doing it wrong.  Remember
that PG is an extensible system and you may be called on to handle
queries that deal with non-built-in types, so even if you had
code for everything appearing in pg_type_d.h, it wouldn't be
exhaustive.  Better to look up type OIDs at runtime.  In the case
of Parse messages, you likely want to let the backend resolve
the parameter types anyway, ie just send zeroes.

            regards, tom lane



pgsql-interfaces by date:

Previous
From: Dave Cramer
Date:
Subject: Re: Object IDs in Parse message
Next
From: Malcolm Matalka
Date:
Subject: Re: Object IDs in Parse message