This page shows how to preview search results using the Google Cloud console and get search results using the API.
Also, instead of using the web app UI, you can make API calls and integrate those calls into your server or application. This page includes code samples for how to make search queries using the gRPC client libraries with a service account.
Get search results
You can preview search results from the Google Cloud console or get search results using the API.
Console
To use the Google Cloud console to preview search results for an app with structured or unstructured data, follow these steps:
- Open the Preview page in the console.
- Type a search query.
- If you enabled autocomplete in step 1, you'll see a list of autocomplete suggestions below the search bar as you type.
 
- (Optional) If you connected multiple data stores to your app but want results only from a specific data store, select the data store to get results from.
- Click Enter to submit the query.
- A list of search results appears below the search bar.
- If no attribute mapping is defined in the Configurations page, each search result appears as a list of raw attribute names and values.
- If any attribute mappings were saved in the Configurations page, the search results display the same images that you see in the Configurations page preview.
 
- If any facets were specified in the Configurations page, they are displayed in the same way.
- Click the arrow below the results list to load the next page of results.
  
  
  
    
  
 To use the API to get search results for an app with structured or unstructured
data, use the  Find your app ID. If you already have your app ID, skip to the next step. In the Google Cloud console, go to the Gemini Enterprise page. On the Apps page, find the name of your app and get the app's ID from
the ID column. Preview search results. Replace the following:REST
  
  
  
  
engines.servingConfigs.search method:
curl -X POST -H "Authorization: Bearer $(gcloud auth print-access-token)" \
-H "Content-Type: application/json" \
"https://discoveryengine.googleapis.com/v1/projects/PROJECT_ID/locations/global/collections/default_collection/engines/APP_ID/servingConfigs/default_search:search" \
-d '{
"query": "QUERY",
"userPseudoId": "USER_PSEUDO_ID",
"pageSize": "PAGE_SIZE",
"offset": "OFFSET",
"orderBy": "ORDER_BY",
"filter": "FILTER",
"boostSpec": "BOOST_SPEC",
"facetSpec": "FACET_SPEC",
"queryExpansionSpec": "QUERY_EXPANSION_SPEC",
"spellCorrectionSpec": "SPELL_CORRECTION_SPEC",
"contentSearchSpec": "CONTENT_SEARCH_SPEC",
"dataStoreSpecs": [{"DATA_STORE_SPEC"}],
}'
PROJECT_ID: the ID of your project.APP_ID: the ID of the app that you want to query.QUERY: the query text to search.USER_PSEUDO_ID: a UTF-8 encoded
string, which acts as a unique pseudonymized identifier that tracks the
users. It can have a maximum length of 128 characters.
Google strongly recommends using this field because it improves
model performance and personalization quality. You can use an HTTP
cookie for this field, which uniquely identifies a visitor on a single
device. Some important considerations are as follows:
- This identifier doesn't change when the visitor signs in or out of a website.
- This field must not be set to the same identifier for multiple users. Otherwise, using the same user ID for multiple users can combine event histories of different users and degrade model quality.
- This field must not include personally identifiable information (PII).
- For a given search or browse request, this field must map to the
      corresponding userPseudoIdfield in the user events.
For more information, see
userPseudoId.
PAGE_SIZE: the number of results returned by
the search. The maximum allowed page size depends on the data type. Page
sizes above the maximum value are coerced to the maximum value.OFFSET: optional. The starting index of the results.
The default value is 0.
For example, if the offset is 2, the page size is 10, and there are 15 results to return, results 2 through 11 are returned on the first page.
ORDER_BY: optional. The order in which the results are
    arranged.
FILTER: optional. A text field for filtering your search
using a filter expression. The default value is an empty string, which
means no filter is applied.
Example: color: ANY("red", "blue") AND score: IN(*, 100.0e)
For more information, see Filter search for structured or unstructured data.
BOOST_SPEC: optional. A specification to
boost or bury documents. Values:
- BOOST: a floating point number in the range [-1,1]. When the value is negative, results are demoted (they appear lower down in the results). When the value is positive, results are promoted (they appear higher up in the results).
- CONDITION: a text filter expression to select the documents to which boost is applied. The filter must evaluate to a boolean value.
To learn about boost for structured search, see Boost search results.
FACET_SPEC: optional. A facet specification to perform
faceted search.
QUERY_EXPANSION_SPEC: optional. A specification to
determine under which conditions query expansion should occur. Default
is DISABLED.
SPELL_CORRECTION_SPEC: optional. A specification to
determine under which conditions spell correction should occur. Default
is AUTO.
CONTENT_SEARCH_SPEC: optional. For getting snippets,
extractive answers, extractive segments, and search summaries. For
unstructured data only. For more information, see:
DATA_STORE_SPEC: filters for a specific data store to search across. This can be used if your search app is connected
to multiple data stores. For more information, see
DataStoreSpec.
Viewing guided search results in the search response:
Guided search results are returned with search responses for structured and unstructured search. The guided search result contains a list of extracted attribute key-value pairs based on search result documents. This allows users to refine their search results by using some attribute keys and values as filters.
In this example response, the color green was used to refine search
results by issuing a new search request with the filter field specified as
_gs.color: ANY("green"):
{
"guidedSearchResult": {
  "refinementAttributes": [
    {
      "attributeKey": "_gs.color",
      "attributeValue": "green"
    },
    {
      "attributeKey": "_gs.category",
      "attributeValue": "shoe"
    }
  ]
}
}
Get document-relevance scores with search results
Document-relevance scores are based on the similarity of the query to the document. Scores are put into 11 buckets in the range: 0, 0.1, 0.2, … to 1.0. The higher the score, the more relevant the document.
Consider document-relevance scores for these use cases:
- Post-search filtering based on the relevance score to remove irrelevant results 
- Post-search ranking or as input to other applications 
- Debugging: relevance scores can provide insight into why some search results are returned 
For each search result, a relevance score can be returned:
  "results": [
    {
      "id": "DOCUMENT_ID",
      "document": {
      ...
      },
      "modelScores": {
        "relevance_score": {
          "values": [
            DOCUMENT-RELEVANCE-SCORE
          ]
        }
      }
    },
    ...
Also see the example command in the procedure below.
Before you begin: Make sure that the search app is associated with a structured or unstructured data store.
REST
To request that document-relevance scores be returned with search results, use
the engines.servingConfigs.search method as
follows:
- Find your app ID. If you already have your app ID, skip to the next step. - In the Google Cloud console, go to the Gemini Enterprise page. 
- On the Apps page, find the name of your app and get the app's ID from the ID column. 
 
- Run the following curl command to get scores returned with search results. - curl -X POST -H "Authorization: Bearer $(gcloud auth print-access-token)" \ -H "Content-Type: application/json" \ "https://discoveryengine.googleapis.com/v1/projects/PROJECT_ID/locations/global/collections/default_collection/engines/APP_ID/servingConfigs/default_search:search" \ -d '{ "servingConfig": "projects/PROJECT_ID/locations/global/collections/default_collection/engines/APP_ID/servingConfigs/default_search", "query": "QUERY", "relevanceScoreSpec": { "returnRelevanceScore": true } }'- PROJECT_ID: the ID of your project.
- APP_ID: the ID of the app that you want to query.
- QUERY: the query text to search.
 
Search summarization differs by model
If you generate search summaries for your queries, you might notice that the summaries differ between the console results and the API results. If you see this, the likely reason is that the console is using a different LLM model from the API. The curl and code examples on this page use the stable LLM model.
- To change or view the LLM model used in the Preview page of the UI, go to the Configurations page > UI tab for your app. 
- For method calls, the stable model is the default model. To use an LLM model other than the stable model, see Specify the summarization model and Specify the answer model.