eba2552086
All subs have be cleaned : - removed useless - merged some - reordering Biblio.pm completly - using only naming conventions Seems to have broken nothing, but it still has to be heavily tested. Note that Biblio.pm is now much more efficient than previously & probably more reliable as well.
50 lines
1.1 KiB
Perl
50 lines
1.1 KiB
Perl
#!/usr/bin/perl
|
|
# This script finds and fixes missing 090 fields in Koha for MARC21
|
|
# Written by TG on 01/10/2005
|
|
# Revised by Joshua Ferraro on 03/31/2006
|
|
use strict;
|
|
|
|
# Koha modules used
|
|
|
|
use C4::Context;
|
|
use C4::Biblio;
|
|
use MARC::Record;
|
|
use MARC::File::USMARC;
|
|
|
|
|
|
my $dbh = C4::Context->dbh;
|
|
|
|
my $sth=$dbh->prepare("select m.bibid,b.biblioitemnumber from marc_biblio m left join biblioitems b on b.biblionumber=m.biblionumber ");
|
|
$sth->execute();
|
|
|
|
while (my ($biblionumber,$biblioitemnumber)=$sth->fetchrow ){
|
|
my $record = MARCgetbiblio($dbh,$biblionumber);
|
|
|
|
MARCmodleader($biblionumber,$record);
|
|
|
|
}
|
|
|
|
sub MARCmodleader{
|
|
my ($biblionumber,$record)=@_;
|
|
|
|
my $update=0;
|
|
#warn "".$record->leader();
|
|
#if (length($record->leader())>24){
|
|
# $record->leader(substr($record->leader,0,24));
|
|
# $update =1;
|
|
#} elsif (length($record->leader())<24){
|
|
$record->leader(' nac 22 1u 4500');
|
|
$update=1;
|
|
#}
|
|
|
|
warn "leader : ".$record->leader if ($biblionumber==2262);
|
|
foreach ($record->field('995')) {
|
|
$record->delete_field($_);
|
|
}
|
|
if ($update){
|
|
&ModBiblioMarc($record,'',$biblionumber);
|
|
print "$biblionumber \n";
|
|
}
|
|
|
|
}
|
|
END;
|