Data Sources - Create Or Update
Creates a new datasource or updates a datasource if it already exists.
PUT {endpoint}/datasources('{dataSourceName}')?api-version=2025-09-01URI Parameters
| Name | In | Required | Type | Description | 
|---|---|---|---|---|
| data | path | True | string | The name of the datasource to create or update. | 
| endpoint | path | True | string | The endpoint URL of the search service. | 
| api-version | query | True | string | Client Api Version. | 
Request Header
| Name | Required | Type | Description | 
|---|---|---|---|
| x-ms-client-request-id | string (uuid) | The tracking ID sent with the request to help with debugging. | |
| If-Match | string | Defines the If-Match condition. The operation will be performed only if the ETag on the server matches this value. | |
| If-None-Match | string | Defines the If-None-Match condition. The operation will be performed only if the ETag on the server does not match this value. | |
| Prefer | True | string | For HTTP PUT requests, instructs the service to return the created/updated resource on success. | 
Request Body
| Name | Required | Type | Description | 
|---|---|---|---|
| container | True | The data container for the datasource. | |
| credentials | True | Credentials for the datasource. | |
| name | True | string | The name of the datasource. | 
| type | True | The type of the datasource. | |
| @odata.etag | string | The ETag of the data source. | |
| dataChangeDetectionPolicy | DataChangeDetectionPolicy: | The data change detection policy for the datasource. | |
| dataDeletionDetectionPolicy | DataDeletionDetectionPolicy: | The data deletion detection policy for the datasource. | |
| description | string | The description of the datasource. | |
| encryptionKey | A description of an encryption key that you create in Azure Key Vault. This key is used to provide an additional level of encryption-at-rest for your datasource definition when you want full assurance that no one, not even Microsoft, can decrypt your data source definition. Once you have encrypted your data source definition, it will always remain encrypted. The search service will ignore attempts to set this property to null. You can change this property as needed if you want to rotate your encryption key; Your datasource definition will be unaffected. Encryption with customer-managed keys is not available for free search services, and is only available for paid services created on or after January 1, 2019. | 
Responses
| Name | Type | Description | 
|---|---|---|
| 200 OK | ||
| 201 Created | ||
| Other Status Codes | Error response. | 
Examples
SearchServiceCreateOrUpdateDataSource     
			Sample request
PUT https://stableexampleservice.search.windows.net/datasources('tempdatasource')?api-version=2025-09-01
{
  "name": "tempdatasource",
  "description": "My Azure Blob data source.",
  "type": "azureblob",
  "credentials": {
    "connectionString": "DefaultEndpointsProtocol=https;AccountName=myAccountName;AccountKey=myAccountKey;EndpointSuffix=core.windows.net "
  },
  "container": {
    "name": "doc-extraction-skillset",
    "query": "E2E_Dsat"
  },
  "dataChangeDetectionPolicy": {
    "highWaterMarkColumnName": "metadata_storage_last_modified",
    "@odata.type": "#Microsoft.Azure.Search.HighWaterMarkChangeDetectionPolicy"
  },
  "dataDeletionDetectionPolicy": {
    "softDeleteColumnName": "isDeleted",
    "softDeleteMarkerValue": "true",
    "@odata.type": "#Microsoft.Azure.Search.SoftDeleteColumnDeletionDetectionPolicy"
  },
  "@odata.etag": "0x1234568AE7E58A1"
}
Sample response
{
  "@odata.etag": "0x1234568AE7E58A1",
  "name": "tempdatasource",
  "description": "My Azure Blob data source.",
  "type": "azureblob",
  "credentials": {
    "connectionString": "DefaultEndpointsProtocol=https;AccountName=myAccountName;AccountKey=myAccountKey;EndpointSuffix=core.windows.net "
  },
  "container": {
    "name": "doc-extraction-skillset",
    "query": "E2E_Dsat"
  },
  "dataChangeDetectionPolicy": {
    "@odata.type": "#Microsoft.Azure.Search.HighWaterMarkChangeDetectionPolicy",
    "highWaterMarkColumnName": "metadata_storage_last_modified"
  },
  "dataDeletionDetectionPolicy": {
    "@odata.type": "#Microsoft.Azure.Search.SoftDeleteColumnDeletionDetectionPolicy",
    "softDeleteColumnName": "isDeleted",
    "softDeleteMarkerValue": "true"
  }
}{
  "@odata.etag": "0x1234568AE7E58A1",
  "name": "tempdatasource",
  "description": "My Azure Blob data source.",
  "type": "azureblob",
  "credentials": {
    "connectionString": "DefaultEndpointsProtocol=https;AccountName=myAccountName;AccountKey=myAccountKey;EndpointSuffix=core.windows.net "
  },
  "container": {
    "name": "doc-extraction-skillset",
    "query": "E2E_Dsat"
  },
  "dataChangeDetectionPolicy": {
    "@odata.type": "#Microsoft.Azure.Search.HighWaterMarkChangeDetectionPolicy",
    "highWaterMarkColumnName": "metadata_storage_last_modified"
  },
  "dataDeletionDetectionPolicy": {
    "@odata.type": "#Microsoft.Azure.Search.SoftDeleteColumnDeletionDetectionPolicy",
    "softDeleteColumnName": "isDeleted",
    "softDeleteMarkerValue": "true"
  }
}Definitions
| Name | Description | 
|---|---|
| Azure | Credentials of a registered application created for your search service, used for authenticated access to the encryption keys stored in Azure Key Vault. | 
| Data | Represents credentials that can be used to connect to a datasource. | 
| Error | The resource management error additional info. | 
| Error | The error detail. | 
| Error | Error response | 
| High | Defines a data change detection policy that captures changes based on the value of a high water mark column. | 
| Search | Represents information about the entity (such as Azure SQL table or CosmosDB collection) that will be indexed. | 
| Search | Represents a datasource definition, which can be used to configure an indexer. | 
| Search | Defines the type of a datasource. | 
| Search | A customer-managed encryption key in Azure Key Vault. Keys that you create and manage can be used to encrypt or decrypt data-at-rest, such as indexes and synonym maps. | 
| Soft | Defines a data deletion detection policy that implements a soft-deletion strategy. It determines whether an item should be deleted based on the value of a designated 'soft delete' column. | 
| Sql | Defines a data change detection policy that captures changes using the Integrated Change Tracking feature of Azure SQL Database. | 
AzureActiveDirectoryApplicationCredentials    
			
			Credentials of a registered application created for your search service, used for authenticated access to the encryption keys stored in Azure Key Vault.
| Name | Type | Description | 
|---|---|---|
| applicationId | string | An AAD Application ID that was granted the required access permissions to the Azure Key Vault that is to be used when encrypting your data at rest. The Application ID should not be confused with the Object ID for your AAD Application. | 
| applicationSecret | string | The authentication key of the specified AAD application. | 
DataSourceCredentials  
			
			Represents credentials that can be used to connect to a datasource.
| Name | Type | Description | 
|---|---|---|
| connectionString | string | The connection string for the datasource. For Azure SQL, Azure Blob, ADLS Gen 2 and Azure Table, this would be the connection string or resource ID if using managed identity. For CosmosDB this would be a formatted connection string specifying ApiKind or resource ID for managed identity. For Onelake files, connection string would be either the workspace guid or workspace FQDN; Onelake only supports managed identity connections. Set to  | 
ErrorAdditionalInfo  
			
			The resource management error additional info.
| Name | Type | Description | 
|---|---|---|
| info | object | The additional info. | 
| type | string | The additional info type. | 
ErrorDetail 
			
			The error detail.
| Name | Type | Description | 
|---|---|---|
| additionalInfo | The error additional info. | |
| code | string | The error code. | 
| details | The error details. | |
| message | string | The error message. | 
| target | string | The error target. | 
ErrorResponse 
			
			Error response
| Name | Type | Description | 
|---|---|---|
| error | The error object. | 
HighWaterMarkChangeDetectionPolicy     
			
			Defines a data change detection policy that captures changes based on the value of a high water mark column.
| Name | Type | Description | 
|---|---|---|
| @odata.type | string: 
					#Microsoft. | A URI fragment specifying the type of data change detection policy. | 
| highWaterMarkColumnName | string | The name of the high water mark column. | 
SearchIndexerDataContainer   
			
			Represents information about the entity (such as Azure SQL table or CosmosDB collection) that will be indexed.
| Name | Type | Description | 
|---|---|---|
| name | string | The name of the table or view (for Azure SQL datasource), collection (for CosmosDB datasource), container (for Azure Blob and ADLS Gen 2 datasources), Azure Table (for Azure Table datasource), or lakehouse (for Onelake datasource) that will be indexed. | 
| query | string | A query that is applied to this data container. For CosmosDB datasource query can flatten and filter data. For Azure Blob and ADLS Gen 2 query can filter by folders. For Azure Table query can filter by row data. For Onelake query can filter by folder or shortcut. Not supported by Azure SQL datasources. | 
SearchIndexerDataSource   
			
			Represents a datasource definition, which can be used to configure an indexer.
| Name | Type | Description | 
|---|---|---|
| @odata.etag | string | The ETag of the data source. | 
| container | The data container for the datasource. | |
| credentials | Credentials for the datasource. | |
| dataChangeDetectionPolicy | DataChangeDetectionPolicy: | The data change detection policy for the datasource. | 
| dataDeletionDetectionPolicy | DataDeletionDetectionPolicy: | The data deletion detection policy for the datasource. | 
| description | string | The description of the datasource. | 
| encryptionKey | A description of an encryption key that you create in Azure Key Vault. This key is used to provide an additional level of encryption-at-rest for your datasource definition when you want full assurance that no one, not even Microsoft, can decrypt your data source definition. Once you have encrypted your data source definition, it will always remain encrypted. The search service will ignore attempts to set this property to null. You can change this property as needed if you want to rotate your encryption key; Your datasource definition will be unaffected. Encryption with customer-managed keys is not available for free search services, and is only available for paid services created on or after January 1, 2019. | |
| name | string | The name of the datasource. | 
| type | The type of the datasource. | 
SearchIndexerDataSourceType    
			
			Defines the type of a datasource.
| Value | Description | 
|---|---|
| azuresql | Definition of an Azure SQL datasource whose credentials can either be a standard SQL connection string or the ResourceId of the SQL resource. The container property refers to the table or view to be indexed. Query parameter is not supported for this datasource. | 
| cosmosdb | Definition of an CosmosDB datasource whose credentials can either be a formatted connection string containing details for AccountEndpoint, AccountKey, and Database for a key based connection or details for ResourceID and ApiKind for keyless connection. The container property refers to cosmosdb collection to be indexed and the optional query property refers to a SQL query on the collection. | 
| azureblob | Definition of an Azure Blob datasource whose credentials can either be a storage connection string or the ResourceId of the storage account. The container property refers to the blob container to be indexed and the optional query property refers to a specific sub-folder in the container. | 
| azuretable | Definition of an Azure Table datasource whose credentials can either be a table connection string or the ResourceId of the storage account. The container property refers to the blob container to be indexed and the optional query property can be used to filter rows. | 
| mysql | Definition of an Azure SQL datasource whose credentials can either be a standard ADO.NET formatted SQL connection string or the ResourceId of the SQL resource. The container property refers to the table or view to be indexed. Query parameter is not supported for this datasource. | 
| adlsgen2 | Definition of an Azure ADLS Gen 2 datasource whose credentials can either be a storage connection string or the ResourceId of the storage account. The container property refers to the blob container to be indexed and the optional query property refers to a specific sub-folder in the container. | 
| onelake | Definition of an Microsoft Fabric Onelake datasource whose credentials can either be the Fabric workspace GUID or a workspace FQDN. The container property refers to the lakehouse GUID and the optional query property refers to folders or shortcuts in the lakehouse. | 
SearchResourceEncryptionKey   
			
			A customer-managed encryption key in Azure Key Vault. Keys that you create and manage can be used to encrypt or decrypt data-at-rest, such as indexes and synonym maps.
| Name | Type | Description | 
|---|---|---|
| accessCredentials | Optional Azure Active Directory credentials used for accessing your Azure Key Vault. Not required if using managed identity instead. | |
| keyVaultKeyName | string | The name of your Azure Key Vault key to be used to encrypt your data at rest. | 
| keyVaultKeyVersion | string | The version of your Azure Key Vault key to be used to encrypt your data at rest. | 
| keyVaultUri | string | The URI of your Azure Key Vault, also referred to as DNS name, that contains the key to be used to encrypt your data at rest. An example URI might be  | 
SoftDeleteColumnDeletionDetectionPolicy     
			
			Defines a data deletion detection policy that implements a soft-deletion strategy. It determines whether an item should be deleted based on the value of a designated 'soft delete' column.
| Name | Type | Description | 
|---|---|---|
| @odata.type | string: 
					#Microsoft. | A URI fragment specifying the type of data deletion detection policy. | 
| softDeleteColumnName | string | The name of the column to use for soft-deletion detection. | 
| softDeleteMarkerValue | string | The marker value that identifies an item as deleted. | 
SqlIntegratedChangeTrackingPolicy    
			
			Defines a data change detection policy that captures changes using the Integrated Change Tracking feature of Azure SQL Database.
| Name | Type | Description | 
|---|---|---|
| @odata.type | string: 
					#Microsoft. | A URI fragment specifying the type of data change detection policy. |