Exploring the Advanced Search Capabilities With MongoDB Atlas Search
Aasawari Sahasrabuddhe6 min read • Published Aug 20, 2024 • Updated Aug 20, 2024
FULL APPLICATION
Rate this tutorial
If you've been following along with the first two parts of our Atlas Search with Spring Boot series, you should already understand Atlas Search concepts and how to craft queries using them. In this article, we'll get into some more advanced topics and features of Atlas Search, enhancing your ability to query data effectively.
For those who still need to explore the earlier parts of the series, I strongly recommend doing so to build a foundational understanding. You can access the previous articles here: Getting Started With MongoDB Atlas Search and Java and Exploring Search Capabilities With Atlas Search.
In this article, we'll explore advanced topics such as creating custom analyzers, utilizing language-specific analyzers, working with GeoJSON data, and performing searches in combination with other aggregation stages like
$lookup
.Let’s get into it!
- Sign up for a MongoDB free tier Atlas account. You can start by following Register to Free Tier to build your Atlas cluster.
- Use Import and Export Data to add the data to the Atlas cluster. The sample data is available in the GitHub repository at productDetails.json and productReviews.json.
- Install Java version 17 or above.
In the previous tutorial, we learned the use of English language analyzers. However, Atlas Search offers a wide range of language analyzers beyond just English. For comprehensive details, you can refer to the official Language Analyzers documentation.
After loading the data into your Atlas cluster from productDetails.json, you'll need to create a search index. You can do this using any of the methods outlined in Part 1 of our series, Getting Started With MongoDB Atlas Search and Java.
To create your search index, you can make use of the below JSON and create an index using the JSON editor on the Atlas UI.
Once the index is created, you can make use of the below Java code:
In this tutorial, since we use two different collections, we pass them as parameters in the search methods.
To run this, you can run the API call as:
and it would give you the output as
In previous tutorials, we explored Atlas's pre-defined analyzers and their use cases. In addition to these, Atlas Search also allows you to create custom analyzers, which can be particularly useful when you need to search for data like product IDs containing alphanumeric characters and hyphens or email addresses.
In this tutorial, we'll build custom analyzers for two different fields and demonstrate how to perform searches using the indexes we create.
For example, in the sample data you've imported, the
_productDetails_
field contains a _productID_
with a value like **ELEC-00123**
. To effectively search within this field, we would configure the index as follows:To search for the productID, we can specify only the numeric or the alphabets to perform the search. The Spring Boot method to perform the search would look like this:
The REST call would look like this:
and it would give you results as:
In the above index, we also have an analyzer created on the productLink field which uses the regex on the links being used. This regex would remove the “//” from the text and allow you to search without using these special characters.
For example, if you wish to search for all products listed on www.amazon.com, the custom analyzer would help you search for the products.
For instance, if we have the search function as:
We can use the REST call as:
and it would result as:
While using the $search operator, it is always expected to use it as the first stage in the pipeline. But if you get into a situation where you need to perform join first and then search, what would you do? Well, this case covers the concept!
When you imported the data into the Atlas cluster, you would also have imported the productReviews.json which contains reviews for the products.
To understand further, let's create a simple index on the productReviews collection:
And let's suppose you wish to get all the product information from both collections which have reviews as _excellent. _
The method would look like:
The REST API call would look like:
and it would result in
This would give all product information with excellent keywords in the reviews.
In this final part of our Atlas Search with Spring Boot series, we've learned more advanced features that Atlas Search offers, such as custom analyzers and language-specific search capabilities. By exploring these topics, we have expanded the ability to design powerful and efficient search queries that cater to complex data retrieval needs.
We discussed custom analyzers to fine-tune search results and perform searches combined with other MongoDB aggregation stages, such as $lookup, to enrich your queries with related data from multiple collections. These techniques will help you create more nuanced and effective search solutions tailored to your specific application requirements.
If you have any questions about the articles, please follow the community forum thread below for questions and discussion. Also, keep exploring other tutorials on our MongoDB Developer Center.
Happy coding!
Top Comments in Forums
There are no comments on this article yet.
This is part of a series