Koha/misc/xmlintobiblioitems.pl
Galen Charlton b8a58c4934 installer: command-line scripts improve finding C4 modules
Command-line scripts now use a new SCRIPT_DIR/kohalib.pl
to put installed location of Koha's Perl modules
into @INC.
2007-12-17 09:13:54 -06:00

46 lines
1.1 KiB
Perl
Executable file

#!/usr/bin/perl
# script that correct the marcxml from in biblioitems
# Written by TG on 10/04/2006
use strict;
BEGIN {
# find Koha's Perl modules
# test carefully before changing this
use FindBin;
eval { require "$FindBin::Bin/kohalib.pl" };
}
# Koha modules used
use C4::Context;
use C4::Biblio;
use MARC::Record;
use MARC::File::USMARC;
use MARC::File::XML;
use Time::HiRes qw(gettimeofday);
my $starttime = gettimeofday;
my $timeneeded;
my $dbh = C4::Context->dbh;
my $sth=$dbh->prepare("select biblionumber,marc from biblioitems ");
$sth->execute();
$dbh->do("LOCK TABLES biblioitems WRITE");
my $i=0;
my $sth2 = $dbh->prepare("UPDATE biblioitems set marcxml=? where biblionumber=?" );
while (my ($biblionumber,$marc)=$sth->fetchrow ){
my $record = MARC::File::USMARC::decode($marc);
my $xml=$record->as_xml_record();
$sth2->execute($xml,$biblionumber);
print "." unless ($i % 100);
$timeneeded = gettimeofday - $starttime unless ($i % 5000);
print "$i records in $timeneeded s\n" unless ($i % 5000);
$i++;
}
$dbh->do("UNLOCK TABLES ");
$timeneeded = gettimeofday - $starttime ;
print "$i records in $timeneeded s\n" ;
END;