From 5ac23dd13c495ff6ce5b7a031ba17f944214cd42 Mon Sep 17 00:00:00 2001 From: Haresh Kainth Date: Wed, 20 Nov 2024 15:01:49 +0000 Subject: [PATCH] chore:enhance search functionality with partial matches Integrated partial matching using TrigramSimilarity and combining search queries for granular full-text search. This improves the search results by accounting for partial word matches and provides a more flexible search experience. --- orp/orp_search/utils/search.py | 27 +++++++++++++++++++++++++-- 1 file changed, 25 insertions(+), 2 deletions(-) diff --git a/orp/orp_search/utils/search.py b/orp/orp_search/utils/search.py index 0ed94b4..c451f78 100644 --- a/orp/orp_search/utils/search.py +++ b/orp/orp_search/utils/search.py @@ -81,10 +81,33 @@ def search_database( # Search across specific fields vector = SearchVector("title", "description", "regulatory_topics") + queryset = DataResponseModel.objects.all() + if query_objs: - queryset = DataResponseModel.objects.annotate(search=vector).filter( - search=query_objs, + # Treat the query for partial and full-text search + query_chunks = query_str.split() + search_vector = SearchVector( + "title", "description", "regulatory_topics" ) + queryset = queryset.annotate(search=search_vector) + + # Creating a combined SearchQuery object from chunks + search_queries = [ + SearchQuery(chunk, search_type="plain") for chunk in query_chunks + ] + combined_query = search_queries[0] + for sq in search_queries[1:]: + combined_query |= sq + + partial_matches = Q() + for chunk in query_chunks: + partial_matches |= ( + Q(title__icontains=chunk) + | Q(description__icontains=chunk) + | Q(regulatory_topics__icontains=chunk) + ) + + queryset = queryset.filter(partial_matches | Q(search=combined_query)) else: queryset = DataResponseModel.objects.annotate(search=vector)