Skip to main content

Recipe for managing RDB schemas

Project description

This is a zc.buildout recipe that helps managing schema updates on relational databases.

It currently only supports PostgreSQL.

Defining a managed database

A managed database has to be created (CREATEDB) outside of this recipe. The recipe only takes care of initialising an existing database and upgrading the schema subsequently.

Part definitions look like:

[managed_db]
recipe = gocept.rdbmanagement
dbname = mydatabase
eggs = projectegg
schema = projectegg.schemadir

host = localhost
user = username
password = apassword  # XXX not implemented, not given

Where

dbname

is the name of the PostgreSQL database to work with

eggs

is a list of egg requirements that should be activated before looking up the schema directory resource path

schema

is a setuptools resource path that is a managed schema directory

Managed schema directories

A schema directory contains a set of SQL and Python files that are used to manage the schema for a database. A typical directory looks like this:

$ ls schemadir
__init__.py
init.sql
precondition3.py
update1.sql
update2.sql
update3.sql

Notice: A managed schema directory has to be a Python package.

init.sql

  • Creates the schema beginning from an empty database.

  • After init.sql the current generation will be set to the highest generation number as available from the update scripts. Therefore the init.sql always creates a current database schema and no updates will be run.

updateX.sql

  • Update scripts MUST start with a BEGIN statement and end with a COMMIT statement.

  • Update script X will be run from a database at generation X-1.

preconditionX.py

  • Script must contain a function called precondition which takes one parameter which is an open DB-API2-connection to the database.

  • Precondition script X will be run on a database at generation X-1.

  • Precondition script X has to raise an exception to indicate that the database MUST not be updated to generation X.

Changes

0.1.1

  • first public release

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gocept.rdbmanagement-0.1.1.tar.gz (4.6 kB view details)

Uploaded Source

File details

Details for the file gocept.rdbmanagement-0.1.1.tar.gz.

File metadata

File hashes

Hashes for gocept.rdbmanagement-0.1.1.tar.gz
Algorithm Hash digest
SHA256 032ee7ee3433468fdae7f060c8c3bb4b44917eb4f52d61598e0249e17093da82
MD5 830f513dc45877388a37ada5971ee86c
BLAKE2b-256 8d07651e17f42e0a441d493ec91a4ba5be9faf5644bba9111cc0f114a1c0757f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page