Database Change Workflow
For a typical change workflow, a developer first submits the SQL statement for DBA to review. After review is approved, the SQL statement will then be applied to the corresponding database. For a single change, this step would normally be repeated for each environment (e.g. integration, staging, prod).
There are 2 typical workflows employed by the team to deal with database schema changes (DDL) and data changes (DML). UI workflow and GitOps workflow (GitOps).
UI workflow
Classic SQL Review workflow where the developer submits a SQL review ticket directly from Bytebase and waits for the assigned DBA or peer developer to review. Bytebase applies the SQL change after review approved.
GitOps Workflow
Aka Database-as-Code
. Database migration scripts are stored in a git repository. To make schema changes, a developer would create a migration script and submit for review in the corresponding VCS such as GitLab. After the script is approved and merged into the configured branch, Bytebase will automatically kicks off the task to apply the new schema change.
Rollout Time
If you want to roll out changes during non-business hours, you can set a rollout time.
Rollout Process
Execution Order
Database rollout is organized into stages. Each stage can contain multiple tasks. Each task contains one or more SQL statements to be executed.
Tasks run in the following order:
-
Tasks from the late stage must wait until all the tasks from the previous stage reach to the end state.
-
For tasks belong to the same stage:
- Tasks changing the same database run sequentially. A failed task will not block the following task.
- Tasks changing different databases run concurrently.
Task Detail
You can check the running/completed task details.
The logs shows how Bytebase runs SQL statements.
The sessions view shows all active sessions (PostgreSQL only).
Migration Types
Bytebase records the migration history with the migration type information.
Schema Migration
Schema migration is the migration type for DDL statements.
Data Migration
Data migration is the migration type for DML statements.
Baseline Migration
Baseline migration instructs Bytebase to use the latest live schema as the source of truth. This is normally used when schema drift occurs and Bytebase needs to re-establish the baseline based on the latest live schema.
Migration History
Bytebase records the detailed migration history and the before/after schema snapshot for each migration it applies. It also leverages these records to detect schema drifts.