Bug 29697: Replace GetMarcBiblio occurrences with $biblio->metadata->record
[srvgit] / misc / migration_tools / 22_to_30 / 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 #use warnings; FIXME - Bug 2505
7
8 # Koha modules used
9
10 use C4::Context;
11 use C4::Biblio qw( GetMarcFromKohaField ModBiblioMarc );
12 use Koha::Biblios;
13 use MARC::File::USMARC;
14
15 $|=1;
16 my $dbh = C4::Context->dbh;
17
18 my $sth=$dbh->prepare("SELECT biblionumber, biblioitemnumber FROM biblioitems");
19 $sth->execute();
20
21 my $i=1;
22 while (my ($biblionumber,$biblioitemnumber)=$sth->fetchrow ){
23  my $biblio = Koha::Biblios->find($biblionumber);
24  my $record = $biblio->metadata->record;
25     print ".";
26     print "\r$i" unless $i %100;
27     MARCmodbiblionumber($biblionumber,$biblioitemnumber,$record);
28 }
29
30 sub MARCmodbiblionumber{
31     my ($biblionumber,$biblioitemnumber,$record)=@_;
32     
33     return unless $record;
34
35     my ($tagfield,$biblionumtagsubfield) = &GetMarcFromKohaField( "biblio.biblionumber" );
36     my ($tagfield2,$biblioitemtagsubfield) = &GetMarcFromKohaField( "biblio.biblioitemnumber" );
37         
38     my $update=0;
39     if (defined $record) {
40         my $tag = $record->field($tagfield);
41         #warn "ICI : ".$record->as_formatted if $record->subfield('090','a') eq '11546';
42     
43         # check that we have biblionumber at the right place, otherwise, update or create the field.
44         if ($tagfield <10) {
45             unless ($tag && $tag->data() == $biblionumber) {
46                 if ($tag) {
47                     $tag->update($biblionumber);
48                 } else {
49                     my $newrec = MARC::Field->new( $tagfield, $biblionumber);
50                     $record->insert_fields_ordered($newrec);
51                 }
52                 $update=1;
53             }
54         } else {
55             unless ($tag && $tag->subfield($biblionumtagsubfield) == $biblionumber) {
56                 if($tag) {
57                     $tag->update($tagfield => $biblionumber);
58                 } else {
59                     my $newrec = MARC::Field->new( $tagfield,'','', $biblionumtagsubfield => $biblionumber,$biblioitemtagsubfield=>$biblioitemnumber);
60                     $record->insert_fields_ordered($newrec);
61                 }
62                 $update=1;
63             }
64         }
65     } else {
66         warn "problem with :".$biblionumber." , record undefined";
67     }
68
69
70     if ($update){
71         &ModBiblioMarc($record,$biblionumber);
72         print "\n modified : $biblionumber \n";
73     }
74     
75 }
76 END;