More test files
[koha.git] / misc / missing090field.pl
1 #!/usr/bin/perl
2 # This script finds and fixes missing 090 fields in Koha for MARC21
3 #  Written by TG on 01/10/2005
4 #  Revised by Joshua Ferraro on 03/31/2006
5 use strict;
6
7 # Koha modules used
8
9 use C4::Context;
10 use C4::Biblio;
11 use MARC::Record;
12 use MARC::File::USMARC;
13
14
15 my $dbh = C4::Context->dbh;
16
17 my $sth=$dbh->prepare("select m.biblionumber,b.biblioitemnumber from marc_biblio m left join biblioitems b on b.biblionumber=m.biblionumber ");
18     $sth->execute();
19
20 while (my ($biblionumber,$biblioitemnumber)=$sth->fetchrow ){
21  my $record = GetMarcBiblio($biblionumber);
22     
23         MARCmodbiblionumber($biblionumber,$biblioitemnumber,$record);
24     
25 }
26
27 sub MARCmodbiblionumber{
28 my ($biblionumber,$biblioitemnumber,$record)=@_;
29
30 my ($tagfield,$biblionumtagsubfield) = &GetMarcFromKohaField("biblio.biblionumber","");
31 my ($tagfield2,$biblioitemtagsubfield) = &GetMarcFromKohaField("biblio.biblioitemnumber","");
32     
33 my $update=0;
34       my @tags = $record->field($tagfield);
35
36 if (!@tags){
37          
38 my $newrec = MARC::Field->new( $tagfield,'','', $biblionumtagsubfield => $biblionumber,$biblioitemtagsubfield=>$biblioitemnumber);
39     $record->append_fields($newrec);
40  $update=1;
41     }
42
43  
44 if ($update){    
45 &ModBiblioMarc($record,'',$biblionumber);
46     print "$biblionumber \n";
47     }
48
49 }
50 END;