...
Easily navigate through large datasets.
For example, when the call number shares the first 10 characters of the shelving order.
Address preceding and succeeding navigation, especially with large datasets.
Leaving the first and last page pages handling exact and non-exact match
Address effective location facet issues
Address type-specific browsing issues (i.e. sorting and finding exact matches)
...
Non-functional Requirements
Configurability - The solution should allow disabling/enabling indexing by a feature flag.
Maintainability - The solution should allow changes for different call number types, searching for prefixes/suffixes, etc.
Performance - The solution should not impact reindexing time significantly.
[TBD: Create a NFR Page]
Assumptions
...
In
mod-search
PostgreSQL DBcreate a table for call numberstables for call numbers
The following fields should be present in the table
callnumber
table:callnumber_id
effective_callnumber_components
- set of components for a call numbercallnumber
prefix
suffix
callnumber_type_id
volume
enumeration
chronology
copynumber
The following fields should be present in the table
callnumber_instances
table:callnumber_id
item_id
instance_id
shared
tenant_id
location_id
on create/update/delete events for items create a new procedure that would extract call numbers from items
Adjust the Reindexing procedure and Ongoing domain events consuming for items
Create a separate index for call numbers
Refactor browse queries to use
search_after
search_before
queriesThe titles for the browse option can be queried on the fly either from the
instances
table or theinstances
search index
...
Indexing Sequence Diagram
As per the current approach for reindexing the indexing of call numbers is split into two main phases: merge and upload. The merge phase is already present in the reindexing procedure.
Drawio | ||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
...
The flag whether to extract and store call numbers should be stored in the database
The temporary table arrays of records similar to the table structure should be created inside of the procedure based on the main table
create temp table tmp_callnumber (like callnumber including indexes);
to hold call numbers and call number instancesInsert from the temporary table arrays into the main table tables should be ordered to avoid deadlocks on main table indices
Drawio | ||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Browsing Sequence Diagram
...
Drawio | |||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Holding-level Call Numbers
Problem statement
Some libraries do not create items for holdings, and they need to be able to browse the call number on the holdings record. The solution should provide the capability to browse call numbers in the following situations:
A library has only holdings related to instances
A library has both holdings and items related to instances
A library has holdings, but some holdings do not have items
Solution Options
Option | Description | Pros & Cons |
---|---|---|
Dedicated holdings/items callnumber search indexes | Holdings call number browse and item call number browse are separate features and can enabled/disabled through configuration flags per tenant | Pros:
Cons:
|
One search index for all callnumbers | If an instance has items, then only item call numbers are filled. If an instance has holdings but not items, the index is filled with callnumbers from holdings | Pros:
Cons:
|
Addressing the holding-level call number browsing
The proposed solution should reuse an approach similar to item-level indexing and use the same call number-related tables. Currently on the mod-inventory-storage
side items that have no call number, inherit the call numbers from holdings, hence there is no need to insert them in the call number
table. This requires to index items before holdings on the merge stage.