Share via


SearchOptions Class

  • java.lang.Object
    • com.azure.search.documents.models.SearchOptions

public final class SearchOptions

Additional parameters for searchGet operation.

Constructor Summary

Constructor Description
SearchOptions()

Creates an instance of SearchOptions.

Method Summary

Modifier and Type Method and Description
QueryDebugMode getDebugMode()

Get the debug property: Enables a debugging tool that can be used to further explore your search results.

List<String> getFacets()

Get the facets property: The list of facet expressions to apply to the search query.

String getFilter()

Get the filter property: The OData $filter expression to apply to the search query.

List<String> getHighlightFields()

Get the highlightFields property: The list of field names to use for hit highlights.

String getHighlightPostTag()

Get the highlightPostTag property: A string tag that is appended to hit highlights.

String getHighlightPreTag()

Get the highlightPreTag property: A string tag that is prepended to hit highlights.

Double getMinimumCoverage()

Get the minimumCoverage property: A number between 0 and 100 indicating the percentage of the index that must be covered by a search query in order for the query to be reported as a success.

List<String> getOrderBy()

Get the orderBy property: The list of OData $orderby expressions by which to sort the results.

QueryType getQueryType()

Get the queryType property: A value that specifies the syntax of the search query.

List<ScoringParameter> getScoringParameters()

Get the scoringParameters property: The list of parameter values to be used in scoring functions (for example, referencePointParameter) using the format name-values.

String getScoringProfile()

Get the scoringProfile property: The name of a scoring profile to evaluate match scores for matching documents in order to sort the results.

ScoringStatistics getScoringStatistics()

Get the scoringStatistics property: A value that specifies whether we want to calculate scoring statistics (such as document frequency) globally for more consistent scoring, or locally, for lower latency.

List<String> getSearchFields()

Get the searchFields property: The list of field names to which to scope the full-text search.

SearchMode getSearchMode()

Get the searchMode property: A value that specifies whether any or all of the search terms must be matched in order to count the document as a match.

List<String> getSelect()

Get the select property: The list of fields to retrieve.

SemanticSearchOptions getSemanticSearchOptions()

Gets the semantic search options.

String getSessionId()

Get the sessionId property: A value to be used to create a sticky session, which can help to get more consistent results.

Integer getSkip()

Get the skip property: The number of search results to skip.

Integer getTop()

Get the top property: The number of search results to retrieve.

VectorSearchOptions getVectorSearchOptions()

Get the vector search options for vector and hybrid search queries.

Boolean isTotalCountIncluded()

Get the includeTotalCount property: A value that specifies whether to fetch the total count of results.

SearchOptions setDebugMode(QueryDebugMode debug)

Set the debug property: Enables a debugging tool that can be used to further explore your search results.

SearchOptions setFacets(String[] facets)

Set the facets property: The list of facet expressions to apply to the search query.

SearchOptions setFilter(String filter)

Set the filter property: The OData $filter expression to apply to the search query.

SearchOptions setHighlightFields(String[] highlightFields)

Set the highlightFields property: The list of field names to use for hit highlights.

SearchOptions setHighlightPostTag(String highlightPostTag)

Set the highlightPostTag property: A string tag that is appended to hit highlights.

SearchOptions setHighlightPreTag(String highlightPreTag)

Set the highlightPreTag property: A string tag that is prepended to hit highlights.

SearchOptions setIncludeTotalCount(Boolean includeTotalCount)

Set the includeTotalCount property: A value that specifies whether to fetch the total count of results.

SearchOptions setMinimumCoverage(Double minimumCoverage)

Set the minimumCoverage property: A number between 0 and 100 indicating the percentage of the index that must be covered by a search query in order for the query to be reported as a success.

SearchOptions setOrderBy(String[] orderBy)

Set the orderBy property: The list of OData $orderby expressions by which to sort the results.

SearchOptions setQueryType(QueryType queryType)

Set the queryType property: A value that specifies the syntax of the search query.

SearchOptions setScoringParameters(ScoringParameter[] scoringParameters)

Set the scoringParameters property: The list of parameter values to be used in scoring functions (for example, referencePointParameter) using the format name-values.

SearchOptions setScoringProfile(String scoringProfile)

Set the scoringProfile property: The name of a scoring profile to evaluate match scores for matching documents in order to sort the results.

SearchOptions setScoringStatistics(ScoringStatistics scoringStatistics)

Set the scoringStatistics property: A value that specifies whether we want to calculate scoring statistics (such as document frequency) globally for more consistent scoring, or locally, for lower latency.

SearchOptions setSearchFields(String[] searchFields)

Set the searchFields property: The list of field names to which to scope the full-text search.

SearchOptions setSearchMode(SearchMode searchMode)

Set the searchMode property: A value that specifies whether any or all of the search terms must be matched in order to count the document as a match.

SearchOptions setSelect(String[] select)

Set the select property: The list of fields to retrieve.

SearchOptions setSemanticSearchOptions(SemanticSearchOptions semanticSearchOptions)

Sets the semantic search options.

SearchOptions setSessionId(String sessionId)

Set the sessionId property: A value to be used to create a sticky session, which can help to get more consistent results.

SearchOptions setSkip(Integer skip)

Set the skip property: The number of search results to skip.

SearchOptions setTop(Integer top)

Set the top property: The number of search results to retrieve.

SearchOptions setVectorSearchOptions(VectorSearchOptions vectorSearchOptions)

Sets the vector search options for vector and hybrid search queries.

Methods inherited from java.lang.Object

Constructor Details

SearchOptions

public SearchOptions()

Creates an instance of SearchOptions.

Method Details

getDebugMode

public QueryDebugMode getDebugMode()

Get the debug property: Enables a debugging tool that can be used to further explore your search results.

Returns:

the debug value.

getFacets

public List<String> getFacets()

Get the facets property: The list of facet expressions to apply to the search query. Each facet expression contains a field name, optionally followed by a comma-separated list of name:value pairs.

Returns:

the facets value.

getFilter

public String getFilter()

Get the filter property: The OData $filter expression to apply to the search query.

Returns:

the filter value.

getHighlightFields

public List<String> getHighlightFields()

Get the highlightFields property: The list of field names to use for hit highlights. Only searchable fields can be used for hit highlighting.

Returns:

the highlightFields value.

getHighlightPostTag

public String getHighlightPostTag()

Get the highlightPostTag property: A string tag that is appended to hit highlights. Must be set with highlightPreTag. Default is .

Returns:

the highlightPostTag value.

getHighlightPreTag

public String getHighlightPreTag()

Get the highlightPreTag property: A string tag that is prepended to hit highlights. Must be set with highlightPostTag. Default is .

Returns:

the highlightPreTag value.

getMinimumCoverage

public Double getMinimumCoverage()

Get the minimumCoverage property: A number between 0 and 100 indicating the percentage of the index that must be covered by a search query in order for the query to be reported as a success. This parameter can be useful for ensuring search availability even for services with only one replica. The default is 100.

Returns:

the minimumCoverage value.

getOrderBy

public List<String> getOrderBy()

Get the orderBy property: The list of OData $orderby expressions by which to sort the results. Each expression can be either a field name or a call to either the geo.distance() or the search.score() functions. Each expression can be followed by asc to indicate ascending, and desc to indicate descending. The default is ascending order. Ties will be broken by the match scores of documents. If no OrderBy is specified, the default sort order is descending by document match score. There can be at most 32 $orderby clauses.

Returns:

the orderBy value.

getQueryType

public QueryType getQueryType()

Get the queryType property: A value that specifies the syntax of the search query. The default is 'simple'. Use 'full' if your query uses the Lucene query syntax.

Returns:

the queryType value.

getScoringParameters

public List<ScoringParameter> getScoringParameters()

Get the scoringParameters property: The list of parameter values to be used in scoring functions (for example, referencePointParameter) using the format name-values. For example, if the scoring profile defines a function with a parameter called 'mylocation' the parameter string would be "mylocation--122.2,44.8" (without the quotes).

Returns:

the scoringParameters value.

getScoringProfile

public String getScoringProfile()

Get the scoringProfile property: The name of a scoring profile to evaluate match scores for matching documents in order to sort the results.

Returns:

the scoringProfile value.

getScoringStatistics

public ScoringStatistics getScoringStatistics()

Get the scoringStatistics property: A value that specifies whether we want to calculate scoring statistics (such as document frequency) globally for more consistent scoring, or locally, for lower latency.

Returns:

the scoringStatistics value.

getSearchFields

public List<String> getSearchFields()

Get the searchFields property: The list of field names to which to scope the full-text search. When using fielded search (fieldName:searchExpression) in a full Lucene query, the field names of each fielded search expression take precedence over any field names listed in this parameter.

Returns:

the searchFields value.

getSearchMode

public SearchMode getSearchMode()

Get the searchMode property: A value that specifies whether any or all of the search terms must be matched in order to count the document as a match.

Returns:

the searchMode value.

getSelect

public List<String> getSelect()

Get the select property: The list of fields to retrieve. If unspecified, all fields marked as retrievable in the schema are included.

Returns:

the select value.

getSemanticSearchOptions

public SemanticSearchOptions getSemanticSearchOptions()

Gets the semantic search options.

Returns:

the semantic search options.

getSessionId

public String getSessionId()

Get the sessionId property: A value to be used to create a sticky session, which can help to get more consistent results. As long as the same sessionId is used, a best-effort attempt will be made to target the same replica set. Be wary that reusing the same sessionID values repeatedly can interfere with the load balancing of the requests across replicas and adversely affect the performance of the search service. The value used as sessionId cannot start with a '_' character.

Returns:

the sessionId value.

getSkip

public Integer getSkip()

Get the skip property: The number of search results to skip. This value cannot be greater than 100,000. If you need to scan documents in sequence, but cannot use $skip due to this limitation, consider using $orderby on a totally-ordered key and $filter with a range query instead.

Returns:

the skip value.

getTop

public Integer getTop()

Get the top property: The number of search results to retrieve. This can be used in conjunction with $skip to implement client-side paging of search results. If results are truncated due to server-side paging, the response will include a continuation token that can be used to issue another Search request for the next page of results.

Returns:

the top value.

getVectorSearchOptions

public VectorSearchOptions getVectorSearchOptions()

Get the vector search options for vector and hybrid search queries.

Returns:

the vector search options.

isTotalCountIncluded

public Boolean isTotalCountIncluded()

Get the includeTotalCount property: A value that specifies whether to fetch the total count of results. Default is false. Setting this value to true may have a performance impact. Note that the count returned is an approximation.

Returns:

the includeTotalCount value.

setDebugMode

public SearchOptions setDebugMode(QueryDebugMode debug)

Set the debug property: Enables a debugging tool that can be used to further explore your search results.

Parameters:

debug - the debug value to set.

Returns:

the SearchOptions object itself.

setFacets

public SearchOptions setFacets(String[] facets)

Set the facets property: The list of facet expressions to apply to the search query. Each facet expression contains a field name, optionally followed by a comma-separated list of name:value pairs.

Parameters:

facets - the facets value to set.

Returns:

the SearchOptions object itself.

setFilter

public SearchOptions setFilter(String filter)

Set the filter property: The OData $filter expression to apply to the search query.

Parameters:

filter - the filter value to set.

Returns:

the SearchOptions object itself.

setHighlightFields

public SearchOptions setHighlightFields(String[] highlightFields)

Set the highlightFields property: The list of field names to use for hit highlights. Only searchable fields can be used for hit highlighting.

Parameters:

highlightFields - the highlightFields value to set.

Returns:

the SearchOptions object itself.

setHighlightPostTag

public SearchOptions setHighlightPostTag(String highlightPostTag)

Set the highlightPostTag property: A string tag that is appended to hit highlights. Must be set with highlightPreTag. Default is .

Parameters:

highlightPostTag - the highlightPostTag value to set.

Returns:

the SearchOptions object itself.

setHighlightPreTag

public SearchOptions setHighlightPreTag(String highlightPreTag)

Set the highlightPreTag property: A string tag that is prepended to hit highlights. Must be set with highlightPostTag. Default is .

Parameters:

highlightPreTag - the highlightPreTag value to set.

Returns:

the SearchOptions object itself.

setIncludeTotalCount

public SearchOptions setIncludeTotalCount(Boolean includeTotalCount)

Set the includeTotalCount property: A value that specifies whether to fetch the total count of results. Default is false. Setting this value to true may have a performance impact. Note that the count returned is an approximation.

Parameters:

includeTotalCount - the includeTotalCount value to set.

Returns:

the SearchOptions object itself.

setMinimumCoverage

public SearchOptions setMinimumCoverage(Double minimumCoverage)

Set the minimumCoverage property: A number between 0 and 100 indicating the percentage of the index that must be covered by a search query in order for the query to be reported as a success. This parameter can be useful for ensuring search availability even for services with only one replica. The default is 100.

Parameters:

minimumCoverage - the minimumCoverage value to set.

Returns:

the SearchOptions object itself.

setOrderBy

public SearchOptions setOrderBy(String[] orderBy)

Set the orderBy property: The list of OData $orderby expressions by which to sort the results. Each expression can be either a field name or a call to either the geo.distance() or the search.score() functions. Each expression can be followed by asc to indicate ascending, and desc to indicate descending. The default is ascending order. Ties will be broken by the match scores of documents. If no OrderBy is specified, the default sort order is descending by document match score. There can be at most 32 $orderby clauses.

Parameters:

orderBy - the orderBy value to set.

Returns:

the SearchOptions object itself.

setQueryType

public SearchOptions setQueryType(QueryType queryType)

Set the queryType property: A value that specifies the syntax of the search query. The default is 'simple'. Use 'full' if your query uses the Lucene query syntax.

Parameters:

queryType - the queryType value to set.

Returns:

the SearchOptions object itself.

setScoringParameters

public SearchOptions setScoringParameters(ScoringParameter[] scoringParameters)

Set the scoringParameters property: The list of parameter values to be used in scoring functions (for example, referencePointParameter) using the format name-values. For example, if the scoring profile defines a function with a parameter called 'mylocation' the parameter string would be "mylocation--122.2,44.8" (without the quotes).

Parameters:

scoringParameters - the scoringParameters value to set.

Returns:

the SearchOptions object itself.

setScoringProfile

public SearchOptions setScoringProfile(String scoringProfile)

Set the scoringProfile property: The name of a scoring profile to evaluate match scores for matching documents in order to sort the results.

Parameters:

scoringProfile - the scoringProfile value to set.

Returns:

the SearchOptions object itself.

setScoringStatistics

public SearchOptions setScoringStatistics(ScoringStatistics scoringStatistics)

Set the scoringStatistics property: A value that specifies whether we want to calculate scoring statistics (such as document frequency) globally for more consistent scoring, or locally, for lower latency.

Parameters:

scoringStatistics - the scoringStatistics value to set.

Returns:

the SearchOptions object itself.

setSearchFields

public SearchOptions setSearchFields(String[] searchFields)

Set the searchFields property: The list of field names to which to scope the full-text search. When using fielded search (fieldName:searchExpression) in a full Lucene query, the field names of each fielded search expression take precedence over any field names listed in this parameter.

Parameters:

searchFields - the searchFields value to set.

Returns:

the SearchOptions object itself.

setSearchMode

public SearchOptions setSearchMode(SearchMode searchMode)

Set the searchMode property: A value that specifies whether any or all of the search terms must be matched in order to count the document as a match.

Parameters:

searchMode - the searchMode value to set.

Returns:

the SearchOptions object itself.

setSelect

public SearchOptions setSelect(String[] select)

Set the select property: The list of fields to retrieve. If unspecified, all fields marked as retrievable in the schema are included.

Parameters:

select - the select value to set.

Returns:

the SearchOptions object itself.

setSemanticSearchOptions

public SearchOptions setSemanticSearchOptions(SemanticSearchOptions semanticSearchOptions)

Sets the semantic search options.

Parameters:

semanticSearchOptions - the semantic search options.

Returns:

the SearchOptions object itself.

setSessionId

public SearchOptions setSessionId(String sessionId)

Set the sessionId property: A value to be used to create a sticky session, which can help to get more consistent results. As long as the same sessionId is used, a best-effort attempt will be made to target the same replica set. Be wary that reusing the same sessionID values repeatedly can interfere with the load balancing of the requests across replicas and adversely affect the performance of the search service. The value used as sessionId cannot start with a '_' character.

Parameters:

sessionId - the sessionId value to set.

Returns:

the SearchOptions object itself.

setSkip

public SearchOptions setSkip(Integer skip)

Set the skip property: The number of search results to skip. This value cannot be greater than 100,000. If you need to scan documents in sequence, but cannot use $skip due to this limitation, consider using $orderby on a totally-ordered key and $filter with a range query instead.

Parameters:

skip - the skip value to set.

Returns:

the SearchOptions object itself.

setTop

public SearchOptions setTop(Integer top)

Set the top property: The number of search results to retrieve. This can be used in conjunction with $skip to implement client-side paging of search results. If results are truncated due to server-side paging, the response will include a continuation token that can be used to issue another Search request for the next page of results.

Parameters:

top - the top value to set.

Returns:

the SearchOptions object itself.

setVectorSearchOptions

public SearchOptions setVectorSearchOptions(VectorSearchOptions vectorSearchOptions)

Sets the vector search options for vector and hybrid search queries.

Parameters:

vectorSearchOptions - the vector search options.

Returns:

the SearchOptions object itself.

Applies to