--- loncom/metadata_database/searchcat.pl 2001/04/16 12:10:26 1.5 +++ loncom/metadata_database/searchcat.pl 2001/04/16 13:45:20 1.11 @@ -10,6 +10,7 @@ use IO::File; use HTML::TokeParser; +use DBI; my @metalist; # ----------------- Code to enable 'find' subroutine listing of the .meta files @@ -17,7 +18,7 @@ require "find.pl"; sub wanted { (($dev,$ino,$mode,$nlink,$uid,$gid) = lstat($_)) && -f _ && - /^.*\.meta$/ && + /^.*\.meta$/ && !/^.+\.\d+\.[^\.]+\.meta$/ && push(@metalist,"$dir/$_"); } @@ -55,23 +56,34 @@ foreach my $user (@homeusers) { } # -- process each file to get metadata and put into search catalog SQL database +# Also, check to see if already there. +# I could just delete (without searching first), but this works for now. foreach my $m (@metalist) { my $ref=&metadata($m); - my $sth=$dbh->prepare('insert into metadata values ('. - delete($ref->{'title'}), - delete($ref->{'author'}).','. - delete($ref->{'subject'}).','. - delete($ref->{'url'}).','. - delete($ref->{'keywords'}).','. - delete($ref->{'version'}).','. - delete($ref->{'notes'}).','. - delete($ref->{'abstract'}).','. - delete($ref->{'mime'}).','. - delete($ref->{'language'}).','. - delete($ref->{'creationdate'}).','. - delete($ref->{'lastrevisiondate'}).','. - delete($ref->{'owner'}).','. - delete($ref->{'copyright'})); + my $m2='/res/'.&declutter($m); + my $q2="select * from metadata where url like binary '/res/$m2'"; + my $sth = $dbh->prepare($q2); + $sth->execute(); + my $r1=$sth->fetchall_arrayref; + if (@$r1) { + $sth=$dbh->prepare("delete from metadata where url like binary '/res/$m2'"); + $sth->execute(); + } + $sth=$dbh->prepare('insert into metadata values ('. + '"'.delete($ref->{'title'}).'"'.','. + '"'.delete($ref->{'author'}).'"'.','. + '"'.delete($ref->{'subject'}).'"'.','. + '"/res/'.$m2.'"'.','. + '"'.delete($ref->{'keywords'}).'"'.','. + '"'.'current'.'"'.','. + '"'.delete($ref->{'notes'}).'"'.','. + '"'.delete($ref->{'abstract'}).'"'.','. + '"'.delete($ref->{'mime'}).'"'.','. + '"'.delete($ref->{'language'}).'"'.','. + '"'.delete($ref->{'creationdate'}).'"'.','. + '"'.delete($ref->{'lastrevisiondate'}).'"'.','. + '"'.delete($ref->{'owner'}).'"'.','. + '"'.delete($ref->{'copyright'}).'"'.')'); $sth->execute(); }