On 31/01/14 16:21, Tim Bunce wrote:
On Fri, Jan 31, 2014 at 09:11:28AM -0500, John Scoles wrote:
A final note on this.
Seems there was a very very long unknown bug in DBI which was only fix a
few days ago wiht DB 1.6.31
If you mean Callbacks getting an inner handle, that wasn't a bug as such.
More like a design choice that proved non-optimal.
[1]http://blogs.perl.org/mt/mt.fcgi?__mode=view&_type=entry&id=5570&blog_id=2165
That's http://blogs.perl.org/users/byterock/2014/01/callbacks-ate-my-brain.html
I presume.
The end result of this bug was that when callbacks are used on the
statement handle some attributes will not be there so you
programmer who did this
$sth->FETCH( 'ParamValues' ), # WTF? - returns a reference to an array of
hashes
was most likely complaing that the
$sth->{ParamValues},
should return a ref but was just returning undef.
So he 'Kludged' the code to get the value directly with the FETCH which
works
I'm not sure what you're saying here John. Using $sth->FETCH('ParamValues')
is perfectly reasonable. It was required before 1.631 and optional with
1.631+ now that $h->{ParamValues} works.
sort of, but it does bleed memory every so slighly.
Are you sure? This is the first I've heard of such a leak.
Tim.
I've found no evidence of a memory leak with a simple test calling ParamValues
a lot with some parameters. However, I'm not using ORA_VARCHAR2_TABLE. The code
is:
else if (kl==11 && strEQ(key, "ParamValues")) {
HV *pvhv = newHV();
if (imp_sth->all_params_hv) {
SV *sv;
char *key;
I32 keylen;
hv_iterinit(imp_sth->all_params_hv);
while ( (sv = hv_iternextsv(imp_sth->all_params_hv, &key,
&keylen)) ) {
phs_t *phs = (phs_t*)(void*)SvPVX(sv); /*
placeholder struct */
(void)hv_store(pvhv, key, keylen,
newSVsv(phs->sv), 0);
}
}
retsv = newRV_noinc((SV*)pvhv);
cacheit = FALSE;
}
which looks sane to me right now. ORA_VARCHAR2_TABLE seems to do strange things
with parameters I don't quite get right now.
As I said previously to Hélder and John (some of the discussion was off
dbi-users list presumably because it contained log data), although I accept
taking the call to ParamValues out has on this occasion made the problem go
away I don't understand why. I think there is more to this than it so far looks
but without a way of reproducing it myself I won't be spending any more time on
it. If it is reproducible in a standalone script I will happily look again.
Martin