Skip site navigation (1) Skip section navigation (2)

Peripheral Links

Header And Logo

PostgreSQL
| The world's most advanced open source database.

Site Navigation

Search for
  Advanced Search

Re: Binary tx format for an array?




On 23-Jun-06, at 4:32 PM, Mark Lewis wrote:

Hmmm maybe I should read before sending. It appears that both input,
and output can be text. The only catch with output is that you have
to do a describe first to get the types. This may negate any gains on
small result sets, but certainly for large ones it would help.

Disclaimer: this is my first real trip through the v3 protocol and the
JDBC driver source in general.  So take anything below with several
grains of salt.

As far as I can tell from reading the JDBC CVS code, the sequence for
preparing and executing a statement for the first time is:

PREPARE            (name=my_statement)
DESCRIBE STATEMENT (name=my_statement)
SYNC/FLUSH
Read Responses

BIND               (portal=my_portal)
DESCRIBE PORTAL    (name=my_portal)
EXECUTE            (portal=my_portal)
SYNC/FLUSH
Read Responses

So it seems that we could do all text, mixed or all binary parameters
without adding a round trip, because we already do an extra round trip
when a statement is first prepared and we already know all of the
parameter types.

Yup, you could, however the real win here is on parsing the return parameters, going from object to string is not terribly expensive.

Network times are probably a red herring.


We could do all text or all binary outputs without adding a round trip
as well, because you can globally set the output format, but to do mixed
outputs we'd need to execute the DESCRIBE PORTAL to get the return
types, and then (not sure?) execute BIND again with different format
parameters?
Yes, you can do binary results, but consider what happens if someone returns a type the driver doesn't know about ?

-- Mark Lewis





Home | Main Index | Thread Index

Privacy Policy | PostgreSQL Archives hosted by Command Prompt, Inc. | Designed by tinysofa
Copyright © 1996 – 2008 PostgreSQL Global Development Group