Skip to content

coderitter/knight-pg-migration

Repository files navigation

Knight PostgreSQL Migration by Coderitter

A database schema migration lib for PostgreSQL.

Related packages

There is an SQL package knight-sql which helps with building SQL strings. It can be combined with knight-criteria and knight-sql-criteria-filler. If you are looking for a more sophisticated version for database access you can also use knight-orm.

Another helpful PostgreSQL tool is knight-pg-transaction.

Install

npm install knight-pg-migration

Overview

The migration

import { PostgresMigration } from 'knight-pg-migration'
import { Pool } from 'pg'

class DbMigration extends PostgresMigration {

    constructor(pool: Pool) {
        super(pool)
    }

    async migrate() {
        await this.version1()
    }

    async version1() {
        if (await this.getVersion() >= 1) {
            return 
        }

        await this.pool.query(
            'CREATE TABLE IF NOT EXISTS User (' +
            'id SERIAL PRIMARY KEY, ' +
            'email VARCHAR(255), ' +
            'firstName VARCHAR(255), ' +
            'lastName VARCHAR(255)' +
            ');')

        await this.increaseVersion()
    }
}

let migration = new DbMigration
migration.migrate()

The available migration methods

// check if the version table exists
let exists = await migration.versionTableExists()

// create the version table but only if it not exists
await migration.createVersionTable()

// get the version from the version table
let version = await migration.getVersion()

// set the version explicitly (mistakes are your own)
await migration.setVersion(4)

// increase the version to the next version number
let increasedVersion = await migration.increaseVersion()

// get all tables of the database
let tables = await migration.getTables()

// delete all tables from the database
let clearedTables = await migration.clearDatabase()

// clear the database and recreate the schema
await migration.resetDatabase()

About

A database schema migration lib for PostgreSQL

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published