Search Postgresql Archives

Re: Semi-Pseudo Data Types & Procedure Arguments

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Joshua Burns <jdburnz@xxxxxxxxx> writes:
> Has anyone played around with what I would call "Semi-Pseudo Data Types,"
> in which a stored procedure may accept a sub-set of a Pseudo Data Types but
> not just any pseudo data-type, such as any type of string (text, character
> varying, character), any type of integer (smallint, integer, bigint), or a
> single element or an array of elements?

Well, you can already handle such scenarios, no?  Just accept text, or
bigint, and let the existing implicit conversions handle the other
cases.

> -- A stored procedure which can accept two argument, which can be a single
> integer field, or an array of integers.

Those two cases seem unlikely to be supportable by the same
implementation, so it seems more likely that what you'd be doing is just
overloading the function name with two instances, my_fn(int) and
my_fn(int[]).

Another trick that's often used is to use an implementation that isn't
quite as general as the signature might suggest.  For example consider

create function my_add(anyelement, anyelement) returns anyelement as
'select $1 + $2' language sql;

This will work for any data type that has a "+" operator, which is a
smaller scope than the "anyelement" signature implies.  Of course this
particular function is pretty useless compared to just writing "+", but
perhaps the idea will help you.

Anyway, I can't see much value in inventing "anystring" or "anyint".
The former is not distinguishable from "text" at all.  The latter might
have some micro-efficiency gain compared to using "bigint", but probably
not enough to be worth the trouble.

			regards, tom lane


-- 
Sent via pgsql-general mailing list (pgsql-general@xxxxxxxxxxxxxx)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-general




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Postgresql Jobs]     [Postgresql Admin]     [Postgresql Performance]     [Linux Clusters]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Postgresql & PHP]     [Yosemite]
  Powered by Linux