Deploy functionality will be significantly changed in incoming release, this documentation is related to lastest BETA version
Database deploy
DbGate offers mechanism for automatic database deploy. While traditional way to achieve this uses migration SQL scripts, DbGate uses different way by default (migration scripts are also support). You define DB model with YAML files describing table structure and list data, and SQL files describing views, stored procedures and functions. This model is deployed to database, comparing current structure with structure in model, create missing columns and tables abnd update view and procedure definitions. No destructive actions (which could lead to data loss) are performed, so when you remove column or table from model, it remains in database. If you rename column in model, new column with new name is created and old column remains in in database.
Deploy could be invoked from command line (using node scripts), or from DbGate GUI. You could also use compare DB function for visual compare differences between model and real database.
Table yaml format
name: Album # table name
columns:
- name: AlbumId # column name
type: int # data type. is used directly in target SQL engine
autoIncrement: true # column is autoincrement
notNull: true # column is not nullable (default: is nullable)
- name: Title
type: nvarchar(150)
notNull: true
- name: ArtistId
type: int
references: Artist # name of table. Is used for creating foreign key
- name: isDeleted
type: bit
notNull: true
default: 0 # default value
- name: created
type: timestamp
default: current_timestamp
primaryKey:
- AlbumId # list of primary key column names
indexes:
- name: UQ_AlbumTitleArtistId # index name
unique: true # whether index is unique. default=false
columns: # list of index columns
- Title
- ArtistId
data: # static data (only for list tables)
- AlbumId: -1 # values for all columns, which should be filled
Title: Predefined static album
- Names are defined without schema name, one model describes one schema
- Default values are defined as SQL expressions, so if you want to define string, you must use ‘single quotes’
- You could define static data for table
Use of migration scripts
You could combine more traditional migration scripts with DbGate specific deploy management, some more specific objects could be created with migration scripts. Scripts types are determined by file extension, directory layout is the user’s choice, DbGate is not affected by this.
The following script extensions are supported:
*.predeploy.sql
- scripts are run before every deploy process*.install.sql
- scripts are executed only if they are different from previous deploy*.uninstall.sql
- this script is paired to.install.sql
file, is executed before new version of*.install.sql
file is executed*.once.sql
- scripts are executed only once*.postdeploy.sql
- scripts are run before every deploy process
DbGate uses table dbgate_deploy_journal
for tracking of deploy scripts deployed to database. This table is create automatically, when you deploy any project with at least one migration script.
Usage in DbGate GUI
- In connections, database context menu, choose “Export DB model” (Premium only). DB model is saved into directory, or into file. If you plan to use Deploy functionality, choose Data archive or Folder (YAML + SQL) destinations.
- Open archives widget, you should see downloaded model
- In model context menu, you could do some operations with model:
- Generate deploy DB SQL - compares current database (you could see it in statusbar) and generates SQL script, which deploys changes from model into creent database
- Shell: Deploy DB - generates JavaScript shell, which could be used for deploying DB
- Compare with {current database} - graphically compares current database with model (Premium only)
Usage from command line
Copy following script into file deploy.js and update database configuration. Also you should change modelFolder, according to you model folder location.
Running this script requires NodeJs
installed on your computer.
const path = require('path');
const dbgateApi = require('dbgate-api');
dbgateApi.initializeApiEnvironment();
const dbgatePluginPostgres = require('dbgate-plugin-postgres');
dbgateApi.registerPlugins(dbgatePluginPostgres);
async function run() {
await dbgateApi.deployDb({
connection: {
server: process.env.DB_SERVER || 'localhost',
engine: 'postgres@dbgate-plugin-postgres',
password: process.env.DB_PASSWORD || 'test',
user: process.env.DB_USER || 'postgres',
port: process.env.DB_PORT || 5432,
database: process.env.DB_NAME || 'my_database',
},
modelFolder: path.join(__dirname, 'database'),
});
await dbgateApi.finalizer.run();
console.log('Finished job script');
}
dbgateApi.runScript(run);
Then, install required modules, running commands in directory with deploy.js:
npm install dbgate-api
npm install dbgate-plugin-postgres
Run database deploy with running command:
node deploy.js
This script is for PostgreSQL, other database engines requires driver changes.
Thios script coiuld be generated also automatically from DbGate GUI, use “Shell: Deploy DB” context menu from archive folder, then “Copy nodejs script” on generated script will copy valid script. All packages, which are used in require command, must be installed with npm install.