Skip to content

Schema migrations

PgDog expects that all shards have, roughly, the same tables. A notable exception to this rule is partitioned tables, which can have different data tables on different shards. The parent tables should be present on all shards, however.

If a shard has different tables than another, automatic query routing may no work as expected.

How it works

PgDog sends DDL queries to all shards concurrently. A DDL query is a statement that mutates the database schema, for example:

CREATE TABLE IF NOT EXISTS "users" (
  "id" BIGSERIAL PRIMARY KEY,
  "email" VARCHAR NOT NULL UNIQUE
)

This query will be sent to all shards, creating the table on all hosts.

Note

Currently, PgDog doesn't use 2-phase commit, so to make sure migrations can be retried safely, use idempotent statements, like IF NOT EXISTS.

Migrating a specific shard

If you need to run a migration against a specific shard, use manual routing and add the shard number in a query comment.