Quickstart: Use Search explorer to run queries in the Azure portal
In this quickstart, learn how to use Search explorer, a built-in query tool in the Azure portal used for running queries against a search index in Azure AI Search. Use it to test a query or filter expression, or confirm whether content exists in the index.
This quickstart uses an existing index to demonstrate Search explorer.
Tip
Search explorer now supports image search. Quickstart: Image search in Azure portal provides the steps.
Prerequisites
Before you begin, have the following prerequisites in place:
An Azure account with an active subscription. Create an account for free.
An Azure AI Search service. Create a service or find an existing service under your current subscription. You can use a free service for this quickstart.
The realestate-us-sample-index is used for this quickstart. To create the index, use the Import data wizard, choose the built-in sample data, and step through the wizard using all of the default values.
Start Search explorer
In the Azure portal, open the search overview page from the dashboard or find your service.
Open Search explorer from the command bar:
Or use the embedded Search explorer tab on an open index:
Query two ways
There are two approaches for querying in Search explorer.
Query view provides a default search bar. It accepts an empty query or free text query with booleans. For example,
seattle condo +parking
.JSON view supports parameterized queries. Filters, orderby, select, count, searchFields, and all other parameters must be set in JSON view.
Tip
JSON view provides intellisense for parameter name completion. Place the cursor inside the JSON view and type a space character to show a list of all query parameters, or type a single letter like "s" to show just the query parameters starting with "s". Intellisense doesn't exclude invalid parameters so use your best judgement.
Switch to JSON view for parameterized queries. The examples in this article assume JSON view throughout. You can paste JSON examples from this article into the text area.
Run an unspecified query
In Search explorer, POST requests are formulated internally using the Search POST REST API, with responses returned as verbose JSON documents.
For a first look at content, execute an empty search by clicking Search with no terms provided. An empty search is useful as a first query because it returns entire documents so that you can review document composition. On an empty search, there's no search score and documents are returned in arbitrary order ("@search.score": 1
for all documents). By default, 50 documents are returned in a search request.
Equivalent syntax for an empty search is *
or "search": "*"
.
{
"search": "*"
}
Results
Free text search
Free-form queries, with or without operators, are useful for simulating user-defined queries sent from a custom app to Azure AI Search. Only those fields attributed as "searchable" in the index definition are scanned for matches.
You don't need JSON view for a free text query, but we provide it in JSON for consistency with other examples in this article.
Notice that when you provide search criteria, such as query terms or expressions, search rank comes into play. The following example illustrates a free text search. The "@search.score" is a relevance score computed for the match using the default scoring algorithm.
{
"search": "Seattle townhouse `Lake Washington` miele OR thermador appliance"
}
Results
You can use Ctrl-F to search within results for specific terms of interest.
Count of matching documents
Add "count": true
to get the number of matches found in an index. On an empty search, count is the total number of documents in the index. On a qualified search, it's the number of documents matching the query input. Recall that the service returns the top 50 matches by default, so the count might indicate more matches in the index than what's returned in the results.
{
"search": "Seattle townhouse `Lake Washington` miele OR thermador appliance",
"count": true
}
Results
Limit fields in search results
Add "select"` to limit results to the explicitly named fields for more readable output in Search explorer. Only fields marked as "retrievable" in the search index can show up in results.
{
"search": "seattle condo",
"count": true,
"select": "listingId, beds, baths, description, street, city, price"
}
Results
Return next batch of results
Azure AI Search returns the top 50 matches based on the search rank. To get the next set of matching documents, append "top": 100
and "skip": 50
to increase the result set to 100 documents (default is 50, maximum is 1000), skipping the first 50 documents. You can check the document key (listingID) to identify a document.
Recall that you need to provide search criteria, such as a query term or expression, to get ranked results. Notice that search scores decrease the deeper you reach into search results.
{
"search": "seattle condo",
"count": true,
"select": "listingId, beds, baths, description, street, city, price",
"top": 100,
"skip": 50
}
Results
Filter expressions (greater than, less than, equal to)
Use the filter
parameter to specify inclusion or exclusion criteria. The field must be attributed as "filterable" in the index. This example searches for bedrooms greater than 3:
{
"search": "seattle condo",
"count": true,
"select": "listingId, beds, baths, description",
"filter": "beds gt 3"
}
Results
Sorting results
Add orderby
to sort results by another field besides search score. The field must be attributed as "sortable" in the index. In situations where the filtered value is identical (for example, same price), the order is arbitrary, but you can add more criteria for deeper sorting. An example expression you can use to test this out is:
{
"search": "seattle condo",
"count": true,
"select": "listingId, price, beds, baths, description",
"filter": "beds gt 3",
"orderby": "price asc"
}
Results
Takeaways
In this quickstart, you used Search explorer to query an index using the REST API.
Results are returned as verbose JSON documents so that you can view document construction and content, in entirety. The
select
parameter in a query expression can limit which fields are returned.Search results are composed of all fields marked as "retrievable" in the index. Select the adjacent Fields tab to review attributes.
Keyword search, similar to what you might enter in a commercial web browser, are useful for testing an end-user experience. For example, assuming the built-in real estate sample index, you could enter "Seattle apartments lake washington", and then you can use Ctrl-F to find terms within the search results.
Query and filter expressions are articulated in a syntax implemented by Azure AI Search. The default is a simple syntax, but you can optionally use full Lucene for more powerful queries. Filter expressions are articulated in an OData syntax.
Clean up resources
When you're working in your own subscription, it's a good idea at the end of a project to decide whether you still need the resources you created. Resources left running can cost you money. You can delete resources individually or delete the resource group to delete the entire set of resources.
You can find and manage resources in the Azure portal, using the All resources or Resource groups link in the left-navigation pane.
If you're using a free service, remember that you're limited to three indexes, indexers, and data sources. You can delete individual items in the Azure portal to stay under the limit.
Next steps
To learn more about query structures and syntax, use a REST client to create query expressions that use more parts of the API. The Search POST REST API is especially helpful for learning and exploration.