From 27b1acf209b212b4e34d9021cfd20dc177bee47c Mon Sep 17 00:00:00 2001 From: Jonathan Druart Date: Thu, 25 Aug 2016 13:24:19 +0100 Subject: [PATCH] Bug 17196: Fix query builder for item search The item search needs to join on biblio_metadata to allow search on marcxml field Test plan: Launch complex item searches (using marc fields). Signed-off-by: Mason James Signed-off-by: Josef Moravec Signed-off-by: Zeno Tajoli Signed-off-by: Nick Clemens Signed-off-by: Marcel de Rooy Signed-off-by: Kyle M Hall --- C4/Items.pm | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/C4/Items.pm b/C4/Items.pm index e02da3b868..b435fee510 100644 --- a/C4/Items.pm +++ b/C4/Items.pm @@ -112,6 +112,7 @@ This module contains an API for manipulating item records in Koha, and is used by cataloguing, circulation, acquisitions, and serials management. +# FIXME This POD is not up-to-date A Koha item record is stored in two places: the items table and embedded in a MARC tag in the XML version of the associated bib record in C. @@ -1304,7 +1305,6 @@ If this is set, it is set to C. sub GetItemsInfo { my ( $biblionumber ) = @_; my $dbh = C4::Context->dbh; - # note biblioitems.* must be avoided to prevent large marc and marcxml fields from killing performance. require C4::Languages; my $language = C4::Languages::getlanguage(); my $query = " @@ -2659,7 +2659,7 @@ sub _SearchItems_build_where_fragment { $sqlfield = 'more_subfields_xml'; $xpath = '//record/datafield/subfield[@code="' . $marcsubfield . '"]'; } else { - $sqlfield = 'marcxml'; + $sqlfield = 'metadata'; # From biblio_metadata if ($marcfield < 10) { $xpath = "//record/controlfield[\@tag=\"$marcfield\"]"; } else { @@ -2768,11 +2768,16 @@ sub SearchItems { FROM items LEFT JOIN biblio ON biblio.biblionumber = items.biblionumber LEFT JOIN biblioitems ON biblioitems.biblioitemnumber = items.biblioitemnumber + LEFT JOIN biblio_metadata ON biblio_metadata.biblionumber = biblio.biblionumber + WHERE 1 }; if (defined $where_str and $where_str ne '') { - $query .= qq{ WHERE $where_str }; + $query .= qq{ AND $where_str }; } + $query .= q{ AND biblio_metadata.format = 'marcxml' AND biblio_metadata.marcflavour = ? }; + push @where_args, C4::Context->preference('marcflavour'); + my @columns = Koha::Database->new()->schema()->resultset('Item')->result_source->columns; push @columns, Koha::Database->new()->schema()->resultset('Biblio')->result_source->columns; push @columns, Koha::Database->new()->schema()->resultset('Biblioitem')->result_source->columns; -- 2.39.5