Re: [Dbdpg-general] benchmarking old Pg and DBD::Pg - Mailing list pgsql-interfaces
From | Vlad |
---|---|
Subject | Re: [Dbdpg-general] benchmarking old Pg and DBD::Pg |
Date | |
Msg-id | cd70c68105040813475c49c858@mail.gmail.com Whole thread Raw |
In response to | Re: [Dbdpg-general] benchmarking old Pg and DBD::Pg (Vlad <marchenko@gmail.com>) |
Responses |
Re: [Dbdpg-general] benchmarking old Pg and DBD::Pg
|
List | pgsql-interfaces |
Brandon, could you let us know YOUR results with DBD::Pg 1.41 with and w/o patch that I've posted earlier? I just did some surface-deep testing here and here is what I've found: DBD-1.40 - slow DBD-1.41 - fast DBD-1.41, patched - fast. I can't see difference between patched and non patched. so it actually turned out that stock 1.41 already has that problem fixed... Though using UNKNOWN instead of VARCHAR for cases when no type was supplied (as Tom Lane suggested) is still a good idea, I think. My patch needs to be careful reviewed - I'm not familiar with DBD:Pg on a deep enough level to gurantee that it's not screwing anything. On Apr 8, 2005 4:24 PM, Vlad <marchenko@gmail.com> wrote: > Brandon, > > try this patch instead. > > diff -ru DBD-Pg-1.41/dbdimp.c DBD-Pg-1.41-patched/dbdimp.c > --- DBD-Pg-1.41/dbdimp.c Fri Apr 8 16:06:12 2005 > +++ DBD-Pg-1.41-patched/dbdimp.c Fri Apr 8 15:46:50 2005 > @@ -1415,7 +1415,7 @@ > } > else if (NULL == currph->bind_type) { /* "sticky" data type */ > /* This is the default type, but we will honor > defaultval if we can */ > - currph->bind_type = pg_type_data(VARCHAROID); > + currph->bind_type = pg_type_data(UNKNOWNOID); > if (!currph->bind_type) > croak("Default type is bad!!!!???"); > } > diff -ru DBD-Pg-1.41/types.c DBD-Pg-1.41-patched/types.c > --- DBD-Pg-1.41/types.c Fri Apr 8 16:06:23 2005 > +++ DBD-Pg-1.41-patched/types.c Fri Apr 8 15:46:37 2005 > @@ -55,7 +55,7 @@ > {ABSTIMEOID, "abstime", DBDPG_TRUE, null_quote, null_dequote, {0}}, > {RELTIMEOID, "reltime", DBDPG_TRUE, null_quote, null_dequote, {0}}, > {TINTERVALOID, "tinterval", DBDPG_TRUE, null_quote, null_dequote, {0}}, > - {UNKNOWNOID, "unknown", DBDPG_FALSE, null_quote, null_dequote, {0}}, > + {UNKNOWNOID, "unknown", DBDPG_FALSE, quote_varchar, null_dequote, {0}}, > {CIRCLEOID, "circle", DBDPG_FALSE, null_quote, null_dequote, {0}}, > {CASHOID, "money", DBDPG_TRUE, null_quote, null_dequote, {0}}, > {MACADDROID, "MAC address", DBDPG_TRUE, > quote_varchar,dequote_varchar, {0}}, > > > On Apr 8, 2005 4:14 PM, Brandon Metcalf <bmetcalf@nortel.com> wrote: > > m == marchenko@gmail.com writes: > > > > m> --- dbdimp.c.bak Wed Apr 6 16:40:20 2005 > > m> +++ dbdimp.c Fri Apr 8 15:21:29 2005 > > m> @@ -1415,7 +1415,7 @@ > > m> } > > m> else if (NULL == currph->bind_type) { /* "sticky" data type */ > > m> /* This is the default type, but we will honor > > m> defaultval if we can */ > > m> - currph->bind_type = pg_type_data(VARCHAROID); > > m> + currph->bind_type = pg_type_data(UNKNOWNOID); > > m> if (!currph->bind_type) > > m> croak("Default type is bad!!!!???"); > > m> } > > > > Using this patch results in error messages like: > > > > DBD::Pg::st execute failed: ERROR: syntax error at or near "15" at character 158 > > > > Not sure why yet. > > > > -- > > Brandon > > > > -- > Vlad > -- Vlad
pgsql-interfaces by date: