I think I would deal with the tricky parts by doing something less tricky. If your example reflects reality your database table has a primary key. Why not just use the primary key in your update()?. That would make your while loop something like this:

my $abstUP = SQL::Abstract->new(); while( my $row = $sth->fetchrow_hashref() ){ print "$0 : Processing row: ".Dumper($row)."\n"; # $subexec is a subref which takes the row as a hashref # and returns a modified clone of it to be inserted into the db # so, newrow and row have the same keys exactly my $newrow = $subexec->($row, $colnames); print "$0 : result is: ".Dumper($newrow)."\n"; my $newrow_only_colnames = { %{ $newrow }{@$colnames} }; # Update the row my($stmt, @bind) = $abstUP->update($tablename, $newrow_only_col +names, { id => $row->{id} } ); print "executing SQL:\n$stmt\nwith binds:\n@bind\n"; my $sth_upd = $dbh->prepare($stmt); if( ! $sth_upd->execute(@bind) ){ $dbh->rollback(); die "update (and rolling back): ".$dbh->errstr; } }

Note that the above uses $sth_upd for the handle to the update statement. This was done because my refactor does the update while the select is still active, so re-using $sth would clobber the select.

wyant


In reply to Re: SQL: Update column(s) value with extra WHERE by Anonymous Monk
in thread SQL: Update column(s) value with extra WHERE by bliako

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.