On 13/01/11 17:21, Martin J. Evans wrote:
> On 18/11/10 20:24, Martin J. Evans wrote:
>> On 18/11/2010 20:15, Steve Baldwin wrote:
>>> Hi,
>>>
>>> I ran across an issue recently that appears to have existed for quite some
>>> time.
>>>
>>> Consider the following script ...
>>>
>>> #!/usr/bin/perl -w
>>> use strict;
>>> use warnings;
>>> use DBI;
>>>
>>> sub main {
>>>      my $dbh = DBI->connect(
>>>          'dbi:Oracle:',
>>>          'usr/pwd@conn',
>>>          '',
>>>          { PrintError =>  0, AutoCommit =>  0, RaiseError =>  1 },
>>>          );
>>>      my $sql =<<'END_SQL';
>>> SELECT  1 srt, 'AA' txt
>>> FROM    dual
>>> UNION
>>> SELECT  2, 'BBB'
>>> FROM    dual
>>> UNION
>>> SELECT  3, 'CCCC'
>>> FROM    dual
>>> ORDER
>>> BY      1
>>> END_SQL
>>>      my $sth = $dbh->prepare($sql);
>>>      $sth->execute;
>>>      my ($srt, $txt);
>>>      $sth->bind_columns(\($srt, $txt));
>>>      while ($sth->fetch) {
>>>          print "[$srt][$txt] len=" . (length($txt)) . "\n";
>>>      }
>>>      $dbh->disconnect;
>>>      return 0;
>>> }
>>>
>>> exit main();
>>>
>>> Running it produces the following output :
>>>
>>> au-stb-101-144:dev stbaldwin$ ./sb2.plx
>>> [1][AA] len=2
>>> [2][BBB] len=2
>>> [3][CCCC] len=2
>>>
>>> As you can see, even though the data in $txt looks correct, perl thinks the
>>> internal length of the variable is whatever it was after fetching the first
>>> row.  This screws up things like sprintf.
>>>
>>> I'm pretty sure this behaviour is a DBD::Oracle thing rather than a DBI
>>> thing.  I tried an equivalent script with DBD::SQLite and DBD::mysql and
>>> they both returned the length correctly (imo).
>>>
>>> This behaviour exists in 1.23 and 1.26.  I haven't tested any other
>>> versions.
>>>
>>> Thanks,
>>>
>>> Steve
>>
>> I vaguely remember hitting this issue myself some time ago. Perhaps a search 
>> of dbi-users or dbi-dev will find something. I'll try and dig out a 
>> reference tomorrow.
>>
>> Martin
>>
> 
> I suddenly remembered what is probably causing this as I hit a similar 
> problem in DBD::ODBC. It was failing to set magic on the sv for the bound 
> column. This should probably be reported in the rt system for DBD::Oracle. I 
> don't have time right now to look into it and will probably forget again 
> unless it is rt'ed.
> 
> Martin

Appollogies, it appears John already got a patch to fix this and it has already 
been committed.

Martin
-- 
Martin J. Evans
Easysoft Limited
http://www.easysoft.com

Reply via email to