[Koha-patches] [PATCH 1/1] Bug 6566 Checking if DB's records are properly indexed
christophe croullebois
christophe.croullebois at biblibre.com
Thu Jun 21 18:36:25 CEST 2012
From: Christophe Croullebois <christophe.croullebois at biblibre.com>
Small script that checks if each bibliorecord in the DB is properly indexed
use -h to learn more
(MT #6389)
---
misc/migration_tools/checkNonIndexedBiblios.pl | 108 ++++++++++++++++++++++++
1 file changed, 108 insertions(+)
create mode 100755 misc/migration_tools/checkNonIndexedBiblios.pl
diff --git a/misc/migration_tools/checkNonIndexedBiblios.pl b/misc/migration_tools/checkNonIndexedBiblios.pl
new file mode 100755
index 0000000..d14a1fb
--- /dev/null
+++ b/misc/migration_tools/checkNonIndexedBiblios.pl
@@ -0,0 +1,108 @@
+#!/usr/bin/perl
+
+# Copyright 2012 BibLibre
+#
+# This file is part of Koha.
+#
+# Koha is free software; you can redistribute it and/or modify it under the
+# terms of the GNU General Public License as published by the Free Software
+# Foundation; either version 2 of the License, or (at your option) any later
+# version.
+#
+# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
+# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along
+# with Koha; if not, write to the Free Software Foundation, Inc.,
+# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+
+# Small script that checks if each biblio in the DB is properly indexed
+# if it is not and if you use -z the not-indexed biblios are inserted in zebraqueue
+# To test just ommit the -z option you will have the biblionumber of non-indexed biblios and the total
+
+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 MARC::Record;
+use C4::Context;
+use C4::Search;
+use Getopt::Long;
+
+my ( $help, $confirm, $zebraqueue, $silent,$stealth );
+
+GetOptions(
+ 'c' => \$confirm,
+ 'h' => \$help,
+ 'z' => \$zebraqueue,
+ 's' => \$silent,
+ 'st' => \$stealth
+);
+
+if ( $help || ( !$confirm ) ) {
+ print_usage();
+ exit 0;
+}
+
+my $dbh = C4::Context->dbh;
+my $i = 0;
+my $count = 0;
+
+# flushes output
+$| = 1;
+
+my $sth = $dbh->prepare("SELECT biblionumber FROM biblio");
+my $sth_insert = $dbh->prepare("INSERT INTO zebraqueue (biblio_auth_number,operation,server,done) VALUES (?,'specialUpdate','biblioserver',0)");
+
+# We get all biblios
+$sth->execute;
+my ($nbhits);
+
+# We check for each biblio
+while ( my ($biblionumber) = $sth->fetchrow ) {
+ (undef,undef,$nbhits) = SimpleSearch("Local-number=$biblionumber");
+ print "biblionumber $biblionumber not indexed\n" unless $nbhits || $stealth;
+# If -z option we put the biblio in zebraqueue
+ if ($zebraqueue && !$nbhits){
+ $sth_insert->execute($biblionumber);
+ print "$biblionumber inserted in zebraqueue\n" unless $stealth;
+ }
+ $i++;
+ print "$i done\n" unless $i % 1000 || $silent || $stealth;
+ $count++ unless $nbhits;
+}
+
+if ($count > 0 && $zebraqueue){
+ print "\t$count bibliorecords not indexed and inserted in zebraqueue\n";
+}
+else{
+ print "\t$count bibliorecords not indexed\n";
+}
+
+sub print_usage {
+ print <<_USAGE_;
+$0: This script takes all biblios and checks if they are indexed in zebra using biblionumber search.
+
+parameters:
+\th this help screen
+\tc confirm (without this parameter, you get the help screen)
+\tz inserts a signal in zebraqueue to force indexing of non indexed biblios otherwise you have only the check
+\ts silent throws no warnings except for non indexed records. Otherwise throws a warn every 1000 biblios to show progress
+\tst stealth do not print warnings for non indexed records and do not warn every 1000
+
+Syntax:
+\t./batchCheckNonIndexedBiblios.pl -h (or without arguments => shows this screen)
+\t./batchCheckNonIndexedBiblios.pl -c (c like confirm => checks all records (may be long)
+\t./batchCheckNonIndexedBiblios.pl -z (z like zebraqueue => inserts in zebraqueue. Without => test only, changes nothing in DB just warns)
+\t./batchCheckNonIndexedBiblios.pl -s (s like silent => don't throws a warn every 1000 biblios to show progress)
+\t./batchCheckNonIndexedBiblios.pl -st (s like stealth => don't throws a warn every 1000 biblios to show progress and no warn for the non indexed biblionumbers, just the total)
+_USAGE_
+}
\ No newline at end of file
--
1.7.9.5
More information about the Koha-patches
mailing list