- Validate delta_count value against pull_batch_count by @tanelsuurhans in #164
- Always quote schema names to support uncommon characters like hyphens by @radhikalism in #166
- Bump thor from 1.3.0 to 1.3.2 by @dependabot in #168
- Bump rspec from 3.12.0 to 3.13.0 by @dependabot in #150
- Bump google-protobuf from 3.25.2 to 3.25.5 by @dependabot in #171
- Bump rexml from 3.2.6 to 3.3.6 by @dependabot in #170
- Bump pg from 1.5.4 to 1.5.8 by @dependabot in #172
- Dependency updates
- Introduce the ability to show estimated progress of copy - #146
- Fix and add links to caveats section in #130
- Refresh views across all schemas post swap in #134
- Validate one constraint at a time in #124
- Introduce --skip-foreign-key-validation in #125
- Resolving gem push and sync glitch in 0.9.3
- Dependency updates
- Adding support for showing the gem version with -v or --version by @brycethornton #101
- Fix for INSERT's failing for long table names by @ahilmer #116
- Get view definition of a view from dedicated schema by @shayonj #117
- Dependency updates
- Create shadow and audit with auatovacuum default turned off. Should avoid lock queues when disabling vacuum on audit table. #97
- Dependency updates and refresh docker release process with multi-platform build
- Gem path and CI fixes
- Ruby 3.1.3 and prettier/ruby #83
- Ruby matrix in ci and require ruby 2.7+ #84
- Re-enable autovacuum by @jfrost #85
- Bump google-protobuf from 3.21.6 to 3.21.7 #76
- Supports tablenames containing uppercase letters #77
- Update rubocop todo #78
- Ensure original triggers are carried over from parent table #79
- off-by-one: Don't skip PK sequence value by one #74
- Update primary key sequence on shadow table #72
- Thanks to @brycethornton for the report
- Only refresh primary key when a sequence is attached #73
NOTE: Skip to 0.7.3. 0.7.2 release missed the change.
- Update primary key sequence on shadow table #72
- Thanks to @brycethornton for the report
- Move CI to Github Actions in #64
- Set --password as optional since it is deprecated in #66
- Smoke tests in #65
- Add foreign keys to parent during swap in #67
- Delete items by audit table PK when replaying by @shayonj @jfrost in #60
- Fixes a race condition issue: #58
- Share some preliminary load test figures in #54
- Reuse existing transaction open for reading table columns in #53
- Start to deprecate --password with PGPASSWORD in #56
- Introduce configurable PULL_BATCH_COUNT and DELTA_COUNT in #57
- Lint sourcecode, setup Rubocop proper and Lint in CI by @shayonj in #46
- Uniquely identify operation_type column by @shayonj in #50
- Introduce primary key on audit table for ordered reads by @shayonj in #49
- This addresses an edge case with replay.
- Uniquely identify trigger_time column by @shayonj in #51
- Abstract assertions into a helper function by @shayonj in #52
- Explicitly call dependencies and bump dependencies by @shayonj #44
- Introduce Dockerfile and release process #45
- Use ISOLATION LEVEL SERIALIZABLE (#42) (props to @jfrost)
Initial release
pg-online-schema-change (pg-osc
) is a tool for making schema changes (any ALTER
statements) in Postgres tables with minimal locks, thus helping achieve zero downtime schema changes against production workloads.
pg-osc
uses the concept of shadow table to perform schema changes. At a high level, it copies the contents from a primary table to a shadow table, performs the schema change on the shadow table and swaps the table names in the end while preserving all changes to the primary table using triggers (via audit table).
Checkout Readme for more details.