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

Paul POULAIN tipaul at users.sourceforge.net
Tue May 14 13:26:12 CEST 2002


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)=@_;
	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";
		}

	}






More information about the Koha-cvs mailing list