koha-cvs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Koha-cvs] CVS: koha/updater thesaurus_create.pl,NONE,1.1


From: Paul POULAIN
Subject: [Koha-cvs] CVS: koha/updater thesaurus_create.pl,NONE,1.1
Date: Tue, 14 May 2002 04:26:12 -0700

Update of /cvsroot/koha/koha/updater
In directory usw-pr-cvs1:/tmp/cvs-serv32679/updater

Added Files:
        thesaurus_create.pl 
Log Message:
First, run updater/thesaurus_create.pl.
It creates a thesaurus table and fills it with data in bibliosubject. Thesaurus
contains 2 columns : freelib and stdlib. This permits connecting differents 
forms for a word/sentence (HUGO may be mapped to V. Hugo, Victor Hugo...)
In modbib.pl, you will see "..." near subject. If you   click on this ..., a 
popup appear. It has 4 parts : the Subject field, a search field with Search 
button. If you enter a value here and click Search, a list of thesaurus entries 
starting by what you enter appear.
If you select a value and click "OK", the value is added to the subject list.
When you've finished, click END. the window is closed, and the value copied to 
main subject window.

Make heavy use of javascript. TESTED UNDER MOZILLA 0.99. Please test under IE.

Administration of thesaurus table will come soon (with html::template) ...



--- NEW FILE ---
#!/usr/bin/perl

use strict;
# This script generates and fill the thesaurus table
# with the data in bibliothesaurus

use C4::Database;
use C4::Catalogue;
use DBI;
use C4::Acquisitions;
use C4::Output;

my $dbh=C4Connect;

sub dosql {
        my ($dbh,$sql_cmd)address@hidden;
        my $sti=$dbh->prepare($sql_cmd);
        $sti->execute;
        if ($sti->err) {
                print "error : ".$sti->errstr." \n tried to execute : 
$sql_cmd\n";
                $sti->finish;
        }
}

my $sth=$dbh->prepare("show tables");
$sth->execute;
my %tables;
while (my ($table) = $sth->fetchrow) {
    $tables{$table}=1;
#    print "table $table\n";
}

print "creating thesaurus...\n";
dosql($dbh,"CREATE TABLE bibliothesaurus (code BIGINT not null AUTO_INCREMENT, 
freelib CHAR (255) not null , stdlib CHAR (255) not null , type CHAR (80) not 
null , PRIMARY KEY (code), INDEX (freelib),index(stdlib),index(type))");
        my $sti=$dbh->prepare("select count(*) as tot from bibliosubject");
        $sti->execute;
        my $total = $sti->fetchrow_hashref;
        my $sti=$dbh->prepare("select subject from bibliosubject");
        $sti->execute;
        my $i;
        while (my $line =$sti->fetchrow_hashref) {
                $i++;
                if ($i % 1000==0) {
                        print "$i / $total->{'tot'}\n";
                }
#               print "$i $line->{'subject'}\n";
                my $sti2=$dbh->prepare("select count(*) as t from 
bibliothesaurus where freelib=".$dbh->quote($line->{'subject'}));
                $sti2->execute;
                if ($sti2->err) {
                        print "error : ".$sti2->errstr."\n";
                        die;
                }
                my $line2=$sti2->fetchrow_hashref;
                if ($line2->{'t'} ==0) {
                        dosql($dbh,"insert into bibliothesaurus 
(freelib,stdlib) values 
(".$dbh->quote($line->{'subject'}).",".$dbh->quote($line->{'subject'}).")");
#               } else {
#                       print "pas ecriture pour : $line->{'subject'}\n";
                }

        }





reply via email to

[Prev in Thread] Current Thread [Next in Thread]