@cardstack/node-pg-migrate v3.0.0-rc2-cardstack.1
node-pg-migrate
Node.js database migration management built exclusively for postgres. (But can also be used for other DBs conforming to SQL standard - e.g. CockroachDB.) Started by Theo Ephraim, now maintained by Salsita Software.
Looking for v2 docs?
see v2 branch.
Installation
$ npm install node-pg-migrateInstalling this module adds a runnable file into your node_modules/.bin directory. If installed globally (with the -g option), you can run node-pg-migrate and if not, you can run ./node_modules/.bin/node-pg-migrate
Usage
You can specify your database connection information using config.
// config/default.json
{
"db": "postgres://postgres:password@localhost:5432/database"
}or
// config/default.json
{
"db": {
"user": "postgres",
"password": "",
"host": "localhost",
"port": 5432,
"database": "database"
}
}You could also specify your database url by setting the environment variable DATABASE_URL.
DATABASE_URL=postgres://postgres@localhost/database node-pg-migrateYou can specify custom JSON file with config (format is same as for db entry of config file), for example:
// path/to/config.json
{
"user": "postgres",
"password": "",
"host": "localhost",
"port": 5432,
"database": "database"
}If a .env file exists, it will be loaded using dotenv (if installed) when running the node-pg-migrate binary.
Depending on your project's setup, it may make sense to write some custom grunt tasks that set this env var and run your migration commands. More on that below.
The following are the available commands:
node-pg-migrate create {migration-name}- creates a new migration file with the name you give it. Spaces and underscores will be replaced by dashes and a timestamp is prepended to your file name.node-pg-migrate up- runs all up migrations from the current state.node-pg-migrate up {N}- runs N up migrations from the current state.node-pg-migrate down- runs a single down migration.node-pg-migrate down {N}- runs N down migrations from the current state.node-pg-migrate redo- redoes last migration (runs a single down migration, then single up migration).node-pg-migrate redo {N}- redoes N last migrations (runs N down migrations, then N up migrations).
Configuration
You can adjust defaults by passing arguments to node-pg-migrate:
config-file(f) - The file with migration JSON config (defaults to undefined)schema(s) - The schema on which migration will be run (defaults topublic)create-schema- Create the configured schema if it doesn't exist (defaults tofalse)database-url-var(d) - Name of env variable with database url string (defaults toDATABASE_URL)migrations-dir(m) - The directory containing your migration files (defaults tomigrations)migrations-schema- The schema storing table which migrations have been run (defaults to same value asschema)create-migrations-schema- Create the configured migrations schema if it doesn't exist (defaults tofalse)migrations-table(t) - The table storing which migrations have been run (defaults topgmigrations)ignore-pattern- Regex pattern for file names to ignore (e.g.ignore_file|\..*|.*\.spec\.js)migration-file-language(j) - Language of the migration file to create (jsorts)timestamp- Treats number argument to up/down migration as timestamp (running up migrations less or equal to timestamp or down migrations greater or equal to timestamp)check-order- Check order of migrations before running them (defaults totrue, to switch it off supply--no-check-orderon command line). (There should be no migration with timestamp lesser than last run migration.)single-transaction- Combines all pending migrations into a single transaction so that if any migration fails, all will be rolled back (defaults totrue, to switch it off supply--no-single-transactionon command line).no-lock- Disables locking mechanism and checks (useful for DBs which does not support SQL commands used for locking)
See all by running node-pg-migrate --help.
Most of configuration options can be also specified in config file.
For SSL connection to DB you can set PGSSLMODE environment variable to value from list other then disable.
e.g. PGSSLMODE=require node-pg-migrate up (pg will take it into account)
JSON Configuration
You can use config or your own json file with configuration (config-file command line option).
Available options are:
migrations-dir,migrations-schema,migrations-table,check-order,ignore-pattern- same as aboveeither
urloruser,password,host(defaults to localhost),port(defaults to 5432),database- for connection details
Locking
node-pg-migrate automatically checks if no other migration is running. To do so, it uses an advisory lock.
Transpiling Babel or Typescript
You can use babel or typescript for transpiling migration files. It requires a little setup to use:
- Update
scriptssection in yourpackage.jsonto contain'migrate': 'node migrate.js' Create
migrate.jsfile with contents:// require('babel-core/register')( { ... your babel config ... } ); // require('ts-node').register( { ... your typescript config ... } ); require('./node_modules/node-pg-migrate/bin/node-pg-migrate');Uncomment/Use either babel or typescript hook and adjust your config for compiler. You can then use migration as usual via e.g.
npm run migrate up. :tada:
Programmatic API
Alongside with command line, you can use node-pg-migrate also programmatically. It exports runner function,
which takes options argument with following structure (similar to command line arguments):
databaseUrlstring or object - Connection string or client config which is passed to new pg.ClientmigrationsTablestring - The table storing which migrations have been runmigrationsSchemastring - The schema storing table which migrations have been run (defaults to same value asschema)schemastring - The schema on which migration will be run (defaults topublic)dirstring - The directory containing your migration filescheckOrderboolean - Check order of migrations before running themdirectionenum -upordowncountnumber - Number of migration to runtimestampboolean - Treatscountas timestampignorePatternstring - Regex pattern for file names to ignorefilestring - Run only migration with this nametypeShorthandsobject - Object with column type shorthandssingleTransactionboolean - Combines all pending migrations into a single transaction so that if any migration fails, all will be rolled back (defaults totrue)createSchemaboolean - Creates the configured schema if it doesn't existcreateMigrationsSchemaboolean - Creates the configured migration schema if it doesn't existnoLockboolean - Disables locking mechanism and checksdryRunboolean
Defining Migrations
When you run node-pg-migrate create a new migration file is created that looks like this:
exports.shorthands = undefined;
exports.up = function up(pgm) {};
exports.down = function down(pgm) {};pgm is a helper object that provides migration operations and run is the callback to call when you are done.
shorthands is optional for column type shorthands. You can specify custom types which will be expanded to column definition
(e.g. for exports.shorthands = { id: { type: 'uuid', primaryKey: true }, createdAt: { type: 'timestamp', notNull: true, default: new PgLiteral('current_timestamp') } };
it will in pgm.createTable('test', { id: 'id', createdAt: 'createdAt' }); produce SQL CREATE TABLE "test" ("id" uuid PRIMARY KEY, "createdAt" timestamp DEFAULT current_timestamp NOT NULL);).
These shorthands are inherited from previous migrations. You can override/change value by simply defining new value for given shorthand name,
if will be used in current and all following migrations (until changed again).
IMPORTANT
Calling the migration functions on pgm doesn't actually migrate your database. These functions just add sql commands to a stack that is run.
Automatic Down Migrations
If exports.down is not present in a migration, node-pg-migrate will try to automatically infer the operations that make up the down migration by reversing the operations of the up migration. Only some operations have automatically inferrable equivalents (details below on each operation). Sometimes, migrations are destructive and cannot be rolled back. In this case, you can set exports.down = false to tell node-pg-migrate that the down migration is impossible.
Async Migrations
In some cases, you may want to perform some async operation during a migration, for example fetching some information from an external server, or inserting some data into the database. To make a migration block operate in async mode, just add another callback argument to the function signature. However, be aware that NONE of the pgm operations will be executed until run() is called. Here's an example:
exports.up = function up(pgm, run) {
doSomethingAsync(function() {
run();
});
};Another way how to perform some async operation is to return Promise from up or down function. Example:
exports.up = function(pgm) {
return new Promise(resolve => {
// doSomethingAsync
resolve();
});
};Migration methods
The pgm object that is passed to each up/down block has many different operations available. Each operation is simply a function that generates some sql and stores it in the current pgm context.
By default, each migration will be run in a transaction. To disable transactions for a specific migration, call pgm.noTransaction()
This is required for some SQL operations that cannot be run within a transaction. It should be used carefully.
Creating & Altering Tables / Columns
pgm.createTable( tablename, columns, options )
Create a new table - postgres docs
Arguments:
tablenamestring - name for the new tablecolumnsobject - column names / options -- see column definitions sectionoptionsobject - table options (optional)temporarybool - default falseifNotExistsbool - default falseinheritsstring - table(s) to inherit fromconstraintsobject - table constraintscheckstring - sql for a check constraintuniquestring or array of strings or array of array of strings - names of unique columnsprimaryKeystring or array of strings - names of primary columnsexcludestring - sql for an exclude constraintdeferrableboolean - flag for deferrable table constraintdeferredboolean - flag for initially deferred deferrable table constraintforeignKeysobject or array of objects - foreign keys specificationcolumnsstring or array of strings - names of columnsreferencesstring - names of foreign table and column namesonDeletestring - action to perform on deleteonUpdatestring - action to perform on updatematchstring -FULLorSIMPLE
likestring - table(s) to inherit fromcommentstring - adds comment on table
Reverse Operation: dropTable
pgm.dropTable( tablename, options )
Drop existing table - postgres docs
Arguments:
pgm.renameTable( tablename, new_tablename )
Rename a table - postgres docs
Arguments:
Reverse Operation: same operation in opposite direction
pgm.alterTable( tablename, options )
Alter existing table - postgres docs
Arguments:
tablenamestring - name of the table to alteroptionsobject - options:levelSecuritystring -DISABLE,ENABLE,FORCE, orNO FORCE
pgm.addColumns( tablename, new_columns )
Add columns to an existing table - postgres docs
Arguments:
tablenamestring - name of the table to alternew_columnsobject - column names / options -- see column definitions section
Aliases: addColumn
Reverse Operation: dropColumns
pgm.dropColumns( tablename, columns, options )
Drop columns from a table - postgres docs
Arguments:
tablenamestring - name of the table to altercolumnsarray of strings or object - columns to drop (if object, uses keys)optionsobject - options:
Aliases: dropColumn
pgm.renameColumn( tablename, old_column_name, new_column_name )
Rename a column - postgres docs
Arguments:
tablenamestring - name of the table to alterold_column_namestring - current column namenew_column_namestring - new column name
Reverse Operation: same operation in opposite direction
pgm.alterColumn( tablename, column_name, column_options )
Alter a column (default value, type, allow null) - postgres docs
Arguments:
tablenamestring - name of the table to altercolumn_namestring - column to altercolumn_optionsobject - optional new column optionsdefaultstring or null - null, stringtypestring - new datatypenotNullboolean - sets NOT NULL if true or NULL if falseallowNullboolean - sets NULL if true (alternative tonotNull)usingstring - adds USING clause to change values in columncollationstring - adds COLLATE clause to change values in columncommentstring - adds comment on column
pgm.addConstraint( tablename, constraint_name, expression )
Add a named column constraint - postgres docs
Arguments:
tablenamestring - name of the table to alterconstraint_namestring - name for the constraintexpressionstring or object - constraint expression (raw sql) or see constraints section of create table
Aliases: createConstraint
Reverse Operation: dropConstraint
pgm.dropConstraint( tablename, constraint_name, options )
Drop a named column constraint - postgres docs
Arguments:
tablenamestring - name of the table to alterconstraint_namestring - name for the constraintoptionsobject - options:
pgm.renameConstraint( tablename, old_constraint_name, new_constraint_name )
Rename a constraint - postgres docs
Arguments:
tablenamestring - name of the table to alterold_constraint_namestring - current constraint namenew_constraint_namestring - new constraint name
Reverse Operation: same operation in opposite direction
pgm.createIndex( tablename, columns, options )
Create a new index - postgres docs
Arguments:
tablenamestring - name of the table to altercolumnsstring or array of strings - columns to add to the indexoptionsindex options - optional options:
Aliases: addIndex
Reverse Operation: dropIndex
pgm.dropIndex( tablename, columns, options )
Drop an index - postgres docs
Arguments:
tablenamestring - name of the table to altercolumnsstring or array of strings - column names, used only to infer an index nameoptionsindex options - optional options:namestring - name of the index to drop
Extension Operations
pgm.createExtension( extension )
Install postgres extension(s) - postgres docs
Arguments:
extensionstring or array of strings - name(s) of extensions to install
Aliases: addExtension
Reverse Operation: dropExtension
pgm.dropExtension( extension )
Un-install postgres extension(s) - postgres docs
Arguments:
extensionstring or array of strings - name(s) of extensions to install
Type Operations
pgm.createType( type_name, values )
Create a new data type - postgres docs
Arguments:
type_namestring - name of the new typevaluesarray of strings or object if an array the contents are possible values for an enum type, if an object names and types for a composite type
Aliases: addType
Reverse Operation: dropType
pgm.dropType( type_name )
Drop a custom data type - postgres docs
Arguments:
type_namestring - name of the new type
pgm.renameType( type_name, new_type_name )
Rename a data type - postgres docs
Arguments:
pgm.addTypeAttribute( type_name, attribute_name, attribute_type )
Add attribute to an existing data type - postgres docs
Arguments:
type_namestring - name of the typeattribute_namestring - name of the attribute to addattribute_typestring - type of the attribute to add
pgm.dropTypeAttribute( type_name, attribute_name, options )
Drop attribute from a data type - postgres docs
Arguments:
type_namestring - name of the typeattribute_namestring - name of the attribute to dropoptionsobject - options:ifExistsboolean - default false
pgm.setTypeAttribute( type_name, attribute_name, attribute_type )
Set data type of an existing attribute of data type - postgres docs
Arguments:
type_namestring - name of the typeattribute_namestring - name of the attributeattribute_typestring - new type of the attribute
pgm.addTypeValue( type_name, value, options )
Add value to a list of enum data type - postgres docs
Arguments:
pgm.renameTypeAttribute( type_name, attribute_name, new_attribute_name )
Rename an attribute of data type - postgres docs
Arguments:
type_namestring - name of the typeattribute_namestring - name of the attribute to renamenew_attribute_namestring - new name of the attribute
Role Operations
pgm.createRole( role_name, role_options )
Create a new role - postgres docs
Arguments:
role_namestring - name of the new rolerole_optionsobject - options:superuserboolean - default falsecreatedbboolean - default falsecreateroleboolean - default falseinheritboolean - default trueloginboolean - default falsereplicationboolean - default falsebypassrlsbooleanlimitnumber -passwordstring -encryptedboolean - default truevalidstring - timestampinRolestring or array of strings - role or array of rolesrolestring or array of strings - role or array of rolesadminstring or array of strings - role or array of roles
Reverse Operation: dropRole
pgm.dropRole( role_name )
Drop a role - postgres docs
Arguments:
role_namestring - name of the new role
pgm.alterRole( role_name, role_options )
Alter a role - postgres docs
Arguments:
pgm.renameRole( old_role_name, new_role_name )
Rename a role - postgres docs
Arguments:
Function Operations
pgm.createFunction( function_name, function_params, function_options, definition )
Create a new function - postgres docs
Arguments:
function_namestring - name of the new functionfunction_paramsarray - parameters of the new functionEither array of strings or objects. If array of strings, it is interpreted as is, if array of objects:
function_optionsobject - options:definitionstring - definition of function
Reverse Operation: dropFunction
pgm.dropFunction( function_name, function_params, drop_options )
Drop a function - postgres docs
Arguments:
function_namestring - name of the function to dropfunction_paramsarray - seedrop_optionsobject - options:
pgm.renameFunction( old_function_name, function_params, new_function_name )
Rename a function - postgres docs
Arguments:
old_function_namestring - old name of the functionfunction_paramsarray - seenew_function_namestring - new name of the function
Trigger Operations
pgm.createTrigger( table_name, trigger_name, trigger_options )
Create a new trigger - postgres docs
Arguments:
table_namestring - name of the table where the new trigger will livetrigger_namestring - name of the new triggertrigger_optionsobject - options:whenstring -BEFORE,AFTER, orINSTEAD OFoperationstring or array of strings -INSERT,UPDATE[ OF ...],DELETEorTRUNCATEconstraintboolean - creates constraint triggerfunctionstring - the name of procedure to executefunctionArgsarray - parameters of the procedurelevelstring -STATEMENT, orROWconditionstring - condition to met to execute triggerdeferrableboolean - flag for deferrable constraint triggerdeferredboolean - flag for initially deferred deferrable constraint trigger
definitionstring - optional definition of function which will be created with same name as trigger
Reverse Operation: dropTrigger
pgm.dropTrigger( table_name, trigger_name, drop_options )
Drop a trigger - postgres docs
Arguments:
table_namestring - name of the table where the trigger livestrigger_namestring - name of the trigger to dropdrop_optionsobject - options:
pgm.renameTrigger( table_name, old_trigger_name, new_trigger_name )
Rename a trigger - postgres docs
Arguments:
table_namestring - name of the table where the trigger livesold_trigger_namestring - old name of the triggernew_trigger_namestring - new name of the trigger
Schema Operations
pgm.createSchema( schema_name, schema_options )
Create a new schema - postgres docs
Arguments:
Reverse Operation: dropSchema
pgm.dropSchema( schema_name, drop_options )
Drop a schema - postgres docs
Arguments:
pgm.renameSchema( old_schema_name, new_schema_name )
Rename a schema - postgres docs
Arguments:
Domain Operations
pgm.createDomain( domain_name, type, options )
Create a new domain - postgres docs
Arguments:
domain_namestring - name of the new domaintypestring - type of the new domainoptionsobject - options:
Reverse Operation: dropDomain
pgm.dropDomain( domain_name, drop_options )
Drop a domain - postgres docs
Arguments:
pgm.alterDomain( domain_name, type, options )
Alter a domain - postgres docs
Arguments:
pgm.renameDomain( old_domain_name, new_domain_name )
Rename a domain - postgres docs
Arguments:
Sequence Operations
pgm.createSequence( sequence_name, type, options )
Create a new sequence - postgres docs
Arguments:
sequence_namestring - name of the new sequenceoptionsobject - options:temporaryboolean - addsTEMPORARYclauseifNotExistsboolean - addsIF NOT EXISTSclausetypestring - type of the sequenceincrementnumber - sets first value of sequenceminvaluenumber or boolean - sets minimum value of sequence orNO MINVALUE(on false or null value)maxvaluenumber or boolean - sets maximum value of sequencee orNO MAXVALUE(on false or null value)startnumber - sets first value of sequencecachenumber - sets how many sequence numbers should be preallocatedcycleboolean - addsCYCLEorNO CYCLEclause if option is presentownerstring or boolean - sets owner of sequence or no owner (on false or null value)
Reverse Operation: dropSequence
pgm.dropSequence( sequence_name, drop_options )
Drop a sequence - postgres docs
Arguments:
pgm.alterSequence( sequence_name, options )
Alter a sequence - postgres docs
Arguments:
sequence_namestring - name of the new sequenceoptionsobject - options:typestring - type of the sequenceincrementnumber - sets first value of sequenceminvaluenumber or boolean - sets minimum value of sequence orNO MINVALUE(on false or null value)maxvaluenumber or boolean - sets maximum value of sequencee orNO MAXVALUE(on false or null value)startnumber - sets first value of sequence (no effect until restart)restartnumber or boolean - sets first value of sequence or usingstartvalue (on true value)cachenumber - sets how many sequence numbers should be preallocatedcycleboolean - addsCYCLEorNO CYCLEclause if option is presentownerstring or boolean - sets owner of sequence or no owner (on false or null value)
pgm.renameSequence( old_sequence_name, new_sequence_name )
Rename a sequence - postgres docs
Arguments:
old_sequence_namestring - old name of the sequencenew_sequence_namestring - new name of the sequence
Operator Operations
pgm.createOperator( operator_name, options )
Create a new operator - postgres docs
Arguments:
operator_namestring - name of the new operatoroptionsobject - options:procedurestring - name of procedure performing operationleftstring - type of left argumentrightstring - type of right argumentcommutatorstring - name of commutative operatornegatorstring - name of negating operatorrestrictstring - name of restriction procedurejoinstring - name of join procedurehashesboolean - addsHASHESclausemergesboolean - addsMERGESclause
Reverse Operation: dropOperator
pgm.dropOperator( operator_name, drop_options )
Drop a operator - postgres docs
Arguments:
pgm.createOperatorClass( operator_class_name, type, index_method, operator_list, options )
Create a new operator class - postgres docs
Arguments:
operator_class_namestring - name of the new operator classtypestring - data type of the new operator classindex_methodstring - name of the index method of operator classoperator_listarray - of operator objectsoptionsobject - options:
Reverse Operation: dropOperatorClass
pgm.dropOperatorClass( operator_class_name, index_methoddrop_options )
Drop a operator class - postgres docs
Arguments:
operator_class_namestring - name of the operator class to dropindex_methodstring - name of the index method of operator classdrop_optionsobject - options:
pgm.renameOperatorClass( old_operator_class_name, index_method, new_operator_class_name )
Rename a operator class - postgres docs
Arguments:
old_operator_class_namestring - old name of the operator classindex_methodstring - name of the index method of operator classnew_operator_class_namestring - new name of the operator class
pgm.createOperatorFamily( operator_family_name, index_method )
Create a new operator family - postgres docs
Arguments:
operator_family_namestring - name of the new operator familyindex_methodstring - name of the index method of operator family
Reverse Operation: dropOperatorFamily
pgm.dropOperatorFamily( operator_family_name, index_methoddrop_options )
Drop a operator family - postgres docs
Arguments:
operator_family_namestring - name of the operator family to dropindex_methodstring - name of the index method of operator familydrop_optionsobject - options:
pgm.renameOperatorFamily( old_operator_family_name, index_method, new_operator_family_name )
Rename a operator family - postgres docs
Arguments:
old_operator_family_namestring - old name of the operator familyindex_methodstring - name of the index method of operator familynew_operator_family_namestring - new name of the operator family
pgm.addToOperatorFamily( operator_family_name, index_method, operator_list )
Rename a operator family - postgres docs
Arguments:
operator_family_namestring - name of the operator familyindex_methodstring - name of the index method of operator familyoperator_listarray - of operator objects
pgm.removeFromOperatorFamily( operator_family_name, index_method, operator_list )
Rename a operator family - postgres docs
Arguments:
operator_family_namestring - name of the operator familyindex_methodstring - name of the index method of operator familyoperator_listarray - of operator objects
Operator List Definitions
Some functions for defining operators take as parameter operator_list which is array of objects with following structure:
typestring -functionoroperatornumbernumber - indexnamestring - name of operator or procedureparamsarray - list of argument types of operator or procedure
Policies
pgm.createPolicy( tableName, policyName, options )
Create a new policy - postgres docs
Arguments:
tableNamestring - name of the table to alterpolicyNamestring - name of the new policyoptionsobject - options:commandstring -ALL,SELECT,INSERT,UPDATE, orDELETErolestring or array - the role(s) to which the policy is to be appliedusingstring - SQL conditional expression for visibility checkcheckstring - SQL conditional expression for insert/update check
Reverse Operation: dropPolicy
pgm.dropPolicy( tableName, policyName, options )
Drop a policy - postgres docs
Arguments:
tableNamestring - name of the table where the policy ispolicyNamestring - name of the policy to deleteoptionsobject - options:ifExistsboolean - drops policy only if it exists
pgm.alterPolicy( tableName, policyName, options )
Alter a policy - postgres docs
Arguments:
tableNamestring - name of the table where the policy ispolicyNamestring - name of the policy to alteroptionsobject - options:rolestring or array - the role(s) to which the policy is to be appliedusingstring - SQL conditional expression for visibility checkcheckstring - SQL conditional expression for insert/update check
pgm.renamePolicy( tableName, policyName, newPolicyName )
Rename a policy - postgres docs
Arguments:
tableNamestring - name of the table where the policy ispolicyNamestring - old name of the policynewPolicyNamestring - new name of the policy
Views
pgm.createView( viewName, options, definition )
Create a new view - postgres docs
Arguments:
viewNamestring - name of the new viewoptionsobject - options:temporaryboolean - default falsereplaceboolean - default falserecursiveboolean - default falsecolumnsstring or array - use if you want to name columns differently then inferred from definitioncheckOptionstring -CASCADEDorLOCAL
definitionstring - SQL of SELECT statement
Reverse Operation: dropView
pgm.dropView( viewName, options )
Drop a view - postgres docs
Arguments:
pgm.alterView( viewName, options )
Alter a view - postgres docs
Arguments:
viewNamestring - name of the view to alteroptionsobject - options:checkOptionstring -CASCADED,LOCALornullto drop
pgm.alterViewColumn( viewName, columnName, options )
Alter a view column - postgres docs
Arguments:
viewNamestring - name of the view to altercolumnNamestring - name of the column to alteroptionsobject - options:defaultstring - default value of column
pgm.renameView( viewName, newViewName )
Rename a view - postgres docs
Arguments:
Materialized Views
pgm.createMaterializedView( viewName, options, definition )
Create a new materialized view - postgres docs
Arguments:
viewNamestring - name of the new materialized viewoptionsobject - options:ifNotExistsboolean - default falsecolumnsstring or array - use if you want to name columns differently then inferred from definitiontablespacestringstorageParametersobject - key value pairs of Storage Parametersdataboolean - default undefined
definitionstring - SQL of SELECT statement
Reverse Operation: dropMaterializedView
pgm.dropMaterializedView( viewName, options )
Drop a materialized view - postgres docs
Arguments:
pgm.alterMaterializedView( viewName, options )
Alter a materialized view - postgres docs
Arguments:
viewNamestring - name of the view to alteroptionsobject - options:clusterstring - index name for clusteringextensionstring - name of extension view is dependent onstorageParametersobject - key value pairs of Storage Parameters
pgm.renameMaterializedView( viewName, newViewName )
Rename a materialized view - postgres docs
Arguments:
pgm.renameMaterializedViewColumn( viewName, columnName, newColumnName )
Rename a materialized view column - postgres docs
Arguments:
viewNamestring - name of the view to altercolumnNamestring - current column namenewColumnNamestring - new column name
pgm.refreshMaterializedView( viewName, options )
Refreshes a materialized view - postgres docs
Arguments:
Miscellaneous Operations
pgm.sql( sql )
Run raw sql -- with some optional very basic mustache templating
Arguments:
pgm.func( sql )
Inserts raw string, which is not escaped
e.g. pgm.func('CURRENT_TIMESTAMP') to use in default option for column definition
Arguments:
sqlstring - string to not be escaped
pgm.db.query and pgm.db.select
Allows to run DB queries with same DB connection migration is running See pg.Client.query
Returns promise with either result of query or returned rows of query (in case of select).
Column Definitions
The createTable and addColumns methods both take a columns argument that specifies column names and options. It is a object (key/value) where each key is the name of the column, and the value is another object that defines the options for the column.
typestring - data type (use normal postgres types)collationstring - collation of data typeuniqueboolean - set to true to add a unique constraint on this columnprimaryKeyboolean - set to true to make this column the primary keynotNullboolean - set to true to make this column not nulldefaultstring - adds DEFAULT clause for column. Accepts null, a literal value, or apgm.func()expression.checkstring - sql for a check constraint for this columnreferencesstring - a table name that this column is a foreign key toonDeletestring - adds ON DELETE constraint for a reference columnonUpdatestring - adds ON UPDATE constraint for a reference columnmatchstring -FULLorSIMPLEdeferrableboolean - flag for deferrable column constraintdeferredboolean - flag for initially deferred deferrable column constraintcommentstring - adds comment on column
Data types & Convenience Shorthand
Data type strings will be passed through directly to postgres, so write types as you would if you were writing the queries by hand.
There are some aliases on types to make things more foolproof: (int, string, float, double, datetime, bool)
There is a shorthand to pass only the type instead of an options object:
pgm.addColumns('myTable', { age: 'integer' });
is equivalent to
pgm.addColumns('myTable', { age: { type: 'integer' } });
There is a shorthand for normal auto-increment IDs:
pgm.addColumns('myTable', { id: 'id' });
is equivalent to
pgm.addColumns('myTable', { id: { type: 'serial', primaryKey: true } });
Using schemas
Instead of passing string as name to pgm functions, you can pass an object with keys schema and name. E.g.
pgm.createTable( {schema: 'my_schema', name: 'my_table_name'}, {id: 'serial'});
will generate
CREATE TABLE "my_schema"."my_table_name" (
"id" serial
);Explanation & Goals
Why only Postgres? - By writing this migration tool specifically for postgres instead of accommadating many databases, we can actually provide a full featured tool that is much simpler to use and maintain. I was tired of using crippled database tools just in case one day we switch our database.
Async / Sync - Everything is async in node, and that's great, but a migration tool should really just be a fancy wrapper that generates SQL. Most other migration tools force you to bring in control flow libraries or wrap everything in callbacks as soon as you want to do more than a single operation in a migration. Plus by building up a stack of operations, we can automatically infer down migrations (sometimes) to save even more time.
Naming / Raw Sql - Many tools force you to use their constants to do things like specify data types. Again, this tool should be a fancy wrapper that generates SQL, so whenever possible, it should just pass through user values directly to the SQL. The hard part is remembering the syntax of the specific operation, not remembering how to type "timestamp"!
License
The MIT License (MIT)
Copyright (c) 2016 Jan Dolezel <dolezel.jan@gmail.com>
Copyright (c) 2014 Theo Ephraim
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.