The Migrations page on the CockroachDB Cloud Console features a Schema Conversion Tool that helps you:
- Convert a schema from a PostgreSQL, MySQL, Oracle, or Microsoft SQL Server database for use with CockroachDB.
Create a new CockroachDB Serverless database that uses the converted schema. You specify the target database and database owner when finalizing the schema. If you are migrating to a CockroachDB Self-Hosted database, you can export the converted schema and execute the statements in
cockroach sql
, or use a third-party schema migration tool such as Alembic, Flyway, or Liquibase.Note:The Migrations page is used to convert a schema for use with CockroachDB and to create a new database that uses the schema. It does not include moving data to the new database. For details on all steps required to complete a database migration, see Migrate Your Database to CockroachDB.
To view this page, select a cluster from the Clusters page, and click Migration in the Data section of the left side navigation.
Convert a schema
The steps to convert your schema depend on your source dialect.
- With the Schemas tab open, click the Add Schema button. This opens the Add SQL Schema dialog.
- In step 1 of the Add SQL Schema dialog, select the appropriate Dialect from the pulldown menu.
- Configure the following defaults for schema conversion:
- INT type conversion: On CockroachDB,
INT
is an alias forINT8
, which creates 64-bit signed integers. On PostgreSQL,INT
defaults toINT4
. For details, see Schema design best practices. - Casing of Identifiers: Select Keep case sensitivity to enclose identifiers in double-quotes, and Make case insensitive to convert identifiers to lowercase. For details on how CockroachDB handles identifiers, see Identifiers.
- AUTO_INCREMENT Conversion Option: We do not recommend using a sequence to define a primary key column. For details, see Schema design best practices. To understand the differences between the
UUID
andunique_rowid()
options, see the SQL FAQs. - Enum Preferences: On CockroachDB,
ENUMS
are a standalone type. On MySQL, they are part of column definitions. You can select to either deduplicate theENUM
definitions or create a separate type for each column. - GENERATED AS IDENTITY Conversion Option: We do not recommend using a sequence to define a primary key column. For details, see Schema design best practices. To understand the differences between the
UUID
andunique_rowid()
options, see the SQL FAQs. - IDENTITY Conversion Option: We do not recommend using a sequence to define a primary key column. For details, see Schema design best practices. To understand the differences between the
UUID
andunique_rowid()
options, see the SQL FAQs.
- INT type conversion: On CockroachDB,
- Click Next.
- Use either the Upload File or Use Credentials option to add your schema.
Upload File
The Schema Conversion Tool expects to analyze a SQL dump file containing only data definition statements.
To generate an appropriate PostgreSQL schema file, run the pg_dump
utility and specify the -s
or --schema-only
options to extract only the schema of a PostgreSQL database to a .sql
file.
To generate an appropriate MySQL schema file, run the mysqldump
utility and specify the -d
or --no-data
options to extract only the schema of the MySQL database to a .sql
file.
To generate an appropriate Oracle schema file, run the expdp
utility to extract only the schema of the Oracle database to a .sql
file.
To generate an appropriate Microsoft SQL Server schema file, use either SQL Server Management Studio or the equivalent mssql-scripter
utility to extract only the schema of the SQL Server database to a .sql
file.
The dump file must be smaller than 4 MB. INSERT
and COPY
statements will be ignored in schema conversion. To add a schema file:
- In step 2 of the Add SQL Schema dialog, click Upload File. Click the upload box and select a
.sql
file, or drop a.sql
file directly into the box. - Click Convert and wait for the schema to be analyzed. A loading screen is displayed. Depending on the size and complexity of the SQL dump, analyzing the schema can require up to several minutes.
- When analysis is complete, review the Summary Report and edit, add, or remove SQL statements in the Statements list.
Use Credentials
This feature is in preview. This feature is subject to change. To share feedback and/or issues, contact Support.
The Schema Conversion Tool can connect directly to a PostgreSQL or MySQL database to obtain the schema. To add a schema using credentials:
- In step 2 of the Add SQL Schema dialog, click Use Credential. Select the credentials to use. If the list is empty, this is because no credentials have been created for the selected database type. You can add credentials directly from the pulldown menu.
Click Convert and wait for the schema to be analyzed. In the background, the Schema Conversion Tool runs the
pg_dump
ormysqldump
utility to obtain the schema.A loading screen is displayed. Depending on the size and complexity of the SQL dump, analyzing the schema can require up to several minutes.
When analysis is complete, review the Summary Report and edit, add, or remove SQL statements in the Statements list.
Add database credentials
Credentials can be added for PostgreSQL and MySQL databases.
- With the Credentials tab open, click the Add Credential button.
- Provide the following information:
- A Credential Name to associate with the credentials.
- The Dialect of the database you are connecting to. Currently, PostgreSQL and MySQL are supported.
- The Host for accessing the database.
- The Port for accessing the database.
- A valid Username and Password for accessing the database.
- The Database Name to access. The Schema Conversion Tool will obtain the schema for this database.
- The SSL Mode for accessing the database:
None
: Do not force a secure connection.Verify CA
: Force a secure connection and verify that the server certificate is signed by a known CA.Verify Full
: Force a secure connection, verify that the server certificate is signed by a known CA, and verify that the server address matches that specified in the certificate.
If the credentials are valid, they will be added to the Credentials table with a VERIFIED
badge.
Review the schema
Summary Report
The Summary Report displays the results of the schema analysis:
- The number of Statements Total in the uploaded
.sql
file that were analyzed. - The number of Errors in SQL statements that are blocking finalization. Errors are further categorized and counted on the Statement Status graph.
- The number of Incidental Errors in SQL statements that are caused by errors in other SQL statements.
- The number of Incompatible Statements that could not be converted because they have no equivalent syntax on CockroachDB.
- The number of Compatibility Notes regarding differences in SQL syntax. Although these statements do not block finalization, you should update them before finalization.
- The number of Suggestions regarding CockroachDB best practices.
To update the schema, click View Statements or the Statements tab to open the Statements list. Errors and suggestions are displayed for each statement.
To finalize the schema and create a new database for migration, click Finalize Schema. The schema must have zero errors.
Statement Status
The Statement Status graph displays the number of successful statements (green), the number of failed statements (red), and the number of incidental errors (orange):
- OK represents a successful statement.
- Unimplemented Feature represents a statement that uses an unimplemented feature.
- Statement Error represents a statement that failed for a reason other than a missing user, unimplemented feature, or incompatible syntax.
- Not Executed represents a statement that was not executed by the tool, such as an
INSERT
orCOPY
statement. - Missing User represents a statement that references a nonexistent user.
- Incompatible represents a statement that could not be converted because it has no equivalent syntax on CockroachDB.
- Incidental Error represents a statement that failed because another SQL statement encountered one of the preceding error types.
Suggestions
The Suggestions graph displays the number of each suggestion type:
- Sequences represents a statement that uses a sequence to define a primary key column. Using a sequence for a primary key column is not recommended.
- Default INT Size represents a statement that was added to change the integer size to
4
. By default, CockroachDB usesINT8
. If you don't want to change the integer size, you can remove this statement in the Statements list. - Missing Primary Key represents a statement that does not define an explicit primary key for a table. Defining an explicit primary key on every table is recommended.
For more details on why these suggestions are made, see Schema design best practices.
Statements list
The Statements list displays the result of analyzing each statement in the .sql
file that you uploaded. The numbers from the Summary Report are displayed above the list of statements.
To finalize the schema and create a new database for migration, click Finalize Schema. The schema must have zero errors.
If the Finalize Schema button is disabled, use the Statements list to update the schema. Navigate the list by scrolling or by clicking the arrows and Scroll to Top button on the bottom-right.
By default, the Statements list displays both successful and failed statements. To view only the statements that failed, check Collapse successful statements.
Statements are displayed as follows:
- A statement that succeeded is displayed without further detail.
- A statement that failed is displayed with
[error]
and a message with error details. If the failure was due to an incidental error, the message also states:This error may automatically resolve once an earlier statement no longer errors
. - A statement that failed due to incompatible syntax is displayed with
[incompat]
, a message with syntax details, and an Acknowledge checkbox. - A statement that has a SQL compatibility issue is displayed with
[compat note]
, a message with syntax details, and an Acknowledge checkbox.Note:Some statements with compatibility issues are automatically removed during conversion. If a statement was removed from the schema, this is stated in the statement's
[incompat]
or[compat note]
message. - A statement that has a suggestion is displayed with
[suggestion]
, a message with suggestion details, and an Acknowledge checkbox.
To edit a statement, click the Edit button or the statement itself and enter your changes. Your changes are saved when you click outside the statement, or when you click the Save button. Click Cancel to discard your changes.
To remove or add a statement, click the ellipsis above the statement and then click Delete statement, Add statement above, or Add statement below.
Update the schema
Respond to errors and suggestions according to the following guidelines:
Type | Solution | Required for finalization |
---|---|---|
Unimplemented feature | The feature does not yet exist on CockroachDB. Implement a workaround by editing the statement and adding statements. Otherwise, remove the statement from the schema. If a link to a tracking issue is included, click the link for further context. For more information about unimplemented features, see Migrate Your Database to CockroachDB. | ✓ |
Statement error | Edit the statement to fix the error. Otherwise, remove the statement from the schema. | ✓ |
Not executed | Remove the statement from the schema. You can include it when moving data to the new database. | ✓ |
Missing user | Click the Add User button next to the error message. You must be a member of the admin role. This adds the missing user to the cluster. |
✓ |
Incidental error | Resolve the error in the earlier failed statement that caused the incidental error. | ✓ |
Incompatible statement (non-PostgreSQL dialects) | There is no equivalent syntax on CockroachDB. Implement a workaround by replacing the statement. Otherwise, remove the statement from the schema. Then check Acknowledge. | ✓ |
Compatibility note (non-PostgreSQL dialects) | Edit the statement to match the CockroachDB syntax. Then optionally check Acknowledge. | ✗ |
Suggestion | Review and take any relevant actions indicated by the message. Then optionally check Acknowledge. | ✗ |
After updating the schema, you must retry the migration to update the Summary Report. This is necessary in order to verify that the schema has zero errors and can be finalized.
To export the current schema, click Export SQL File at the top of the Statements list.
Retry the migration
To analyze a schema that you have updated, click Retry Migration at the top of the Statements list. This updates the Summary Report.
This is necessary in order to verify that the schema has zero errors and can be finalized.
Finalize the schema
You can finalize the schema when the number of errors is zero. This value is displayed on the Schemas table, Summary Report, and Statements list.
To finalize the schema, click Finalize Schema when viewing the Summary Report or Statements list. A modal will open:
In the Success tab, click Next.
In the Create Schema tab, name the new database and select a user to own the database. Optionally click Download SQL export to download your schema file. If you are migrating to a CockroachDB Self-Hosted database, you can export the converted schema and execute the statements in
cockroach sql
, or use a third-party schema migration tool such as Alembic, Flyway, or Liquibase.Click Finalize to create the new database.
After finalizing the schema and creating the new database, move data into the database and test your application.
Schemas table
If you have added a schema to convert, the following details are displayed when the Schemas tab is open:
Column | Description |
---|---|
Migration Name | The filename of the .sql file that you added. |
Status | The status of the migration: READY FOR REVIEW , READY TO FINALIZE , or FINALIZED . You can finalize migrations with READY TO FINALIZE status. |
Date Imported | The timestamp when the SQL dump was uploaded. |
Last Updated | The timestamp when the SQL statements were updated. |
Errors | The number of SQL errors preventing a migration from attaining READY TO FINALIZE status. |
To view the Summary Report or Statements list for a migration, click the migration name.
Credentials table
If you have added any external database credentials (PostgreSQL or MySQL only), the following details are displayed when the Credentials tab is open:
Column | Description |
---|---|
Credential Name | The name associated with the access credentials. A VERIFIED badge will display if the credentials are verified. |
Dialect | The type of database being accessed. |
Host / Port | The host and port used to access the database. |
Database Name | The name of the database being accessed. |
Created At | The timestamp when the credentials were successfully created. |
To delete or verify a set of credentials, select the appropriate option in the Actions column.