Record Migration Mode allows you to migrate large numbers of object records by only enforcing minimal constraints such as data type and length. You can create records in any lifecycle state and manually set standard and system-managed fields such as Name, ID, or Created By.
You can apply Record Migration Mode when creating or updating object records using the Vault API, Vault Loader, the Vault Loader Command Line Tool, configuration migration packages, and test data packages. You must have the Record Migration permission to apply migration mode using these options.
Note: Record Migration Mode is separate from Configuration Mode and has different functionality.
When Record Migration Mode is enabled, Vault allows you to set or edit values for fields that are normally not editable when creating and updating records. However, you cannot set formula fields with Record Migration Mode.
| Item | Requirements | 
|---|---|
| Standard and custom fields | Must be a valid data type and length. Any other type of validation is bypassed.Record Migration Mode applies default values to omitted fields. To make a field value blank, include the field but leave the value empty. | 
| ID | Supported in Create actions only.Must be a unique sequence of 15 uppercase alphanumeric characters, where: 
 For example, 00PZA1B2C3D4E5F. | 
| Global ID | Must be valid and in the format {vault id}_{record id}. | 
| 
 | If you include either Created By or Modified By, you must include both. If you include either the Created Date or the Modified Date, you must include both, and neither date can be in the future. The Created Date must be earlier than or equal to the Modified Date.If omitted, Created By and Modified By default to the currently authenticated user, and Created Date and Modified Date default to Now(). | 
| Picklist values | Must exist but can be inactive. | 
| Object type fields | Fields must exist on the Object Type. | 
| Object references | Must exist but can point to inactive records. | 
| Lifecycle, lifecycle state, and lifecycle stages | Must exist but can be inactive. If omitted, Record Migration Mode applies default values. The default value for a lifecycle state is its initial state. If you include any lifecycle stage fields, you must include all lifecycle stage fields. Status changes on a parent record, such as changing Active to Inactive, do not cascade to its children. Ensure status changes are updated on both the parent and child record. | 
| Lookup fields | Must be the correct data type.You must include the related record ID. For standard volume objects, if a Lookup field value does not match the source record, Record Migration Mode does not overwrite the field value until the related record ID is updated. Raw objects always overwrite the field value with the correct lookup value. | 
| Roll-up fields | Must be the correct data type.If a Roll-up field value does not match the specified child records, Record Migration Mode does not overwrite the field value until the child records are updated. | 
How to Use Record Migration Mode
You must have the Record Migration permission to apply migration mode using these options.
Create Object Records API
Use the Vault API’s Create Object Records and set the X-VaultAPI-MigrationMode header to true, which applies Record Migration Mode to any object record created or updated in that request.
Set the X-VaultAPI-NoTriggers header to true to bypass triggers when Record Migration Mode is enabled. Before using this parameter, learn more about bypassing triggers.
Vault Loader API
Use the Vault API’s Load Data Objects endpoint and set the recordmigrationmode parameter to true.
To also bypass record triggers, set the notriggers parameter to true. Before using this parameter, learn more about bypassing triggers.
Vault Loader UI
When creating or updating records in bulk with Vault Loader, select the Record Migration Mode checkbox to apply migration mode.
The No Triggers option allows you to bypass record triggers. Before using this parameter, learn more about bypassing triggers.
Vault Loader CLI
Use the -recordmigrationmode parameter in the Vault Loader Command Line tool.
To also bypass record triggers, use the -notriggers parameter. Before using this parameter, learn more about bypassing triggers.
Configuration Packages & Test Data Packages
When editing the settings for a data object in a configuration migration package or test data package, select the Record Migration Mode checkbox to apply Record Migration Mode.
About Bypassing Triggers
When using Record Migration Mode with Vault API, Vault Loader, or Vault Loader CLI, you can optionally configure Vault to skip all trigger execution. This includes custom Vault Java SDK triggers, Action Triggers, standard triggers, and system triggers which work to deliver various Vault functionality.
Because standard and system triggers are generally expected to run, bypassing these triggers may have unexpected consequences.
We do not recommend bypassing triggers on the following objects:
- User Role Setup (user_role_setup__v)
- User Role (user_role__sys)
As a best practice, always run your record migration in a sandbox Vault and test for expected functionality before running in production.