From e56a34254da634f34b9e43eaf3f80d6d80ef3f9f Mon Sep 17 00:00:00 2001 From: Mike Rylander Date: Mon, 16 May 2011 18:17:30 -0400 Subject: [PATCH] Ignore "deleted" authority records when using the tag-validation method Signed-off-by: Mike Rylander --- .../perlmods/lib/OpenILS/Application/Storage/Publisher/authority.pm | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Storage/Publisher/authority.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Storage/Publisher/authority.pm index 58cbc011e7..af0dff69b7 100644 --- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Storage/Publisher/authority.pm +++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Storage/Publisher/authority.pm @@ -31,6 +31,7 @@ sub validate_tag { my @searches = @{$args{searches}}; my $search_table = authority::full_rec->table; + my $rec_table = authority::record_entry->table; my @values; my @selects; @@ -53,8 +54,9 @@ sub validate_tag { $sql = 'SELECT COUNT(DISTINCT record) FROM ('; } $sql .= 'SELECT record FROM (('.join(') INTERSECT (', @selects).')) AS x '; - $sql .= "JOIN $search_table recheck USING (record) WHERE recheck.tag = ? "; - $sql .= "GROUP BY 1 HAVING (COUNT(recheck.id) - ?) = 0) AS foo;"; + $sql .= "JOIN $search_table recheck USING (record) "; + $sql .= "JOIN $rec_table delcheck ON (recheck.record = delcheck.id and delcheck.deleted = 'f') "; + $sql .= "WHERE recheck.tag = ? GROUP BY 1 HAVING (COUNT(recheck.id) - ?) = 0) AS foo;"; if ($self->api_name =~ /id_list/) { my $id_list = authority::full_rec->db_Main->selectcol_arrayref( $sql, {}, @values, $t, scalar(@searches) ); -- 2.11.0