You can update the schema for any data containing data that supports a schema, such as structured data, website data with structured data, or other unstructured data with metadata.
You can update the schema in the Google Cloud console or by
using the
schemas.patch API method.
Updating the schema for a website is supported only over the REST API.
To update the schema, you can add new fields, change indexable, searchable, and
retrievable annotations for a field, or mark a field as a key property, such as
title, uri and description.
Update your schema
You can update your schema in the Google Cloud console or using the API.
Console
To update a schema in the Google Cloud console, follow these steps:
- Review the Requirements and limitations section to check that your schema update is valid. 
- If you are updating field annotations (setting fields as indexable, retrievable, dynamic facetable, searchable, or completable), review Configure field settings for the limitations and requirements of each annotation type. 
- Check that you have completed data ingestion. Otherwise, the schema might not be available to edit yet. 
- In the Google Cloud console, go to the AI Applications page. 
- In the navigation menu, click Data Stores. 
- In the Name column, click the data store with the schema that you want to update. 
- Click the Schema tab to view the schema for your data. - This tab might be empty if this is the first time you're editing the fields. 
- Click the Edit button. 
- Update your schema: - Map key properties: In the Key properties column of your schema, select a key property to map a field to. For example, if a field called - detailsalways contains the description of a document, map that field to the key property Description.
- Update number of dimensions (Advanced): You can update this setting if you are using custom vector embeddings with Vertex AI Search. See Advanced: Use custom embeddings. 
- Update field annotations: To update annotations for a field, select or deselect a field's annotation setting. Available annotations are Retrievable, Indexable, Dynamic Facetable, Searchable, and Completable. Some field settings have limitations. See Configure field settings for descriptions and requirements for each annotation type. 
- Add a new field: Adding new fields to your schema before importing new documents with those fields can shorten the time it takes Vertex AI Search to reindex your data after import. - Click Add new fields to expand that section. 
- Click add_box Add node and specify settings for the new field. - To indicate an array, set Array to Yes. For example, to add an array of strings, set type to - stringand Array to- Yes.- For a website data store index, all fields that you add are arrays by default. 
 
 
- Click Save to apply your schema changes. - Changing the schema triggers reindexing. For large data stores, reindexing can take hours. 
REST
To use the API to update your schema, follow these steps:
- Review the Requirements and limitations and the Limitation examples (REST only) sections to check that your schema changes are valid. - To update the schema for data stores with websites or unstructured data with metadata, skip to Step 5 to call the - schema.patchmethod.
- If you are updating field annotations (setting fields as indexable, retrievable, dynamic facetable, or searchable), review Configure field settings for the limitations and requirements of each annotation type. 
- If you are editing an auto-detected schema, make sure that you have completed data ingestion. Otherwise, the schema might not be available to edit yet. 
- Find your data store ID. If you already have your data store ID, skip to the next step. - In the Google Cloud console, go to the AI Applications page and in the navigation menu, click Data Stores. 
- Click the name of your data store. 
- On the Data page for your data store, get the data store ID. 
 
- Use the schemas.patch API method to provide your new JSON schema as a JSON object. - curl -X PATCH \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ -H "Content-Type: application/json" \ "https://discoveryengine.googleapis.com/v1beta/projects/PROJECT_ID/locations/global/collections/default_collection/dataStores/DATA_STORE_ID/schemas/default_schema" \ -d '{ "structSchema": JSON_SCHEMA_OBJECT }'- Replace the following: - PROJECT_ID: the ID of your Google Cloud project.
- DATA_STORE_ID: the ID of the Vertex AI Search data store.
- JSON_SCHEMA_OBJECT: your new JSON schema as a JSON object. For example:- { "$schema": "https://json-schema.org/draft/2020-12/schema", "type": "object", "properties": { "title": { "type": "string", "keyPropertyMapping": "title" }, "categories": { "type": "array", "items": { "type": "string", "keyPropertyMapping": "category" } }, "uri": { "type": "string", "keyPropertyMapping": "uri" } } } 
 
- Optional: Review the schema by following the procedure View a schema definition. 
C#
For more information, see the Vertex AI Search C# API reference documentation.
To authenticate to Vertex AI Search, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Go
For more information, see the Vertex AI Search Go API reference documentation.
To authenticate to Vertex AI Search, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Java
For more information, see the Vertex AI Search Java API reference documentation.
To authenticate to Vertex AI Search, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Python
For more information, see the Vertex AI Search Python API reference documentation.
To authenticate to Vertex AI Search, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Ruby
For more information, see the Vertex AI Search Ruby API reference documentation.
To authenticate to Vertex AI Search, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Requirements and limitations
When updating a schema, be sure that the new schema is backward compatible with the schema you are updating. To update a schema with a new schema that is not backward compatible, you need to delete all the documents in the data store, delete the schema, and create a new schema.
Updating a schema triggers re-indexing of all documents. This can take time and incur additional costs:
- Time. Reindexing a large data store can take hours or days. 
- Expense. Reindexing can incur costs, depending on the parser. For example, reindexing data stores that use the OCR parser or the layout parser both incur costs. For more information, see Document AI feature pricing. 
Schema updates don't support the following:
- Changing a field type. A schema update doesn't support changing the type
of the field. For example, a field mapped to integercan't be changed tostring.
- Removing a field. After it's defined, a field can't be removed. You can continue adding new fields but you can't remove an existing field.
Limitation examples (REST only)
This section shows examples of valid and invalid types of schema updates. These examples use the following example JSON schema:
{
  "$schema": "https://json-schema.org/draft/2020-12/schema",
  "type": "object",
  "properties": {
    "title": {
      "type": "string"
    },
    "description": {
      "type": "string",
      "keyPropertyMapping": "description"
    },
    "categories": {
      "type": "array",
      "items": {
        "type": "string",
        "keyPropertyMapping": "category"
      }
    }
  }
}
Examples of supported updates
The following updates to the example schema are supported.
- Adding a field. In this example, the field - properties.urihas been added to the schema.- { "$schema": "https://json-schema.org/draft/2020-12/schema", "type": "object", "properties": { "title": { "type": "string" }, "description": { "type": "string", "keyPropertyMapping": "description" }, "uri": { // Added field. This is supported. "type": "string", "keyPropertyMapping": "uri" }, "categories": { "type": "array", "items": { "type": "string", "keyPropertyMapping": "category" } } } }
- Adding or removing key property annotations for - title,- descriptionor- uri. In this example,- keyPropertyMappinghas been added to the- titlefield.- { "$schema": "https://json-schema.org/draft/2020-12/schema", "type": "object", "properties": { "title": { "type": "string", "keyPropertyMapping": "title" // Added "keyPropertyMapping". This is supported. }, "description": { "type": "string", "keyPropertyMapping": "description" }, "categories": { "type": "array", "items": { "type": "string", "keyPropertyMapping": "category" } } } }
Examples of invalid schema updates
The following updates to the example schema aren't supported.
- Changing a field type. In this example, the - titlefield's type has been changed from string to number. This is not supported.- { "$schema": "https://json-schema.org/draft/2020-12/schema", "type": "object", "properties": { "title": { "type": "number" // Changed from string. Not allowed. }, "description": { "type": "string", "keyPropertyMapping": "description" }, "categories": { "type": "array", "items": { "type": "string", "keyPropertyMapping": "category" } } } }
- Removing a field. In this example, the - titlefield has been removed. This is not supported.- { "$schema": "https://json-schema.org/draft/2020-12/schema", "type": "object", "properties": { // "title" is removed. Not allowed. "description": { "type": "string", "keyPropertyMapping": "description" }, "uri": { "type": "string", "keyPropertyMapping": "uri" }, "categories": { "type": "array", "items": { "type": "string", "keyPropertyMapping": "category" } } } }
What's next
- View the schema definition for structured data
- Delete a schema for structured data
- Preview search results