SQLite

Supported Versions

  • 3.7 and later 3.x versions

Drivers

Java (Xerial)
URL format jdbc:sqlite:database
Maven Central coordinates org.xerial:sqlite-jdbc:3.30.1
Supported versions 3.7 and later
Default Java class org.sqlite.JDBC

SQL Script Syntax

Compatibility

  • DDL exported by SQLite can be used unchanged in a MigrateDB migration
  • Any SQLite SQL script executed by MigrateDB, can be executed by the SQLite tools (after the placeholders have been replaced)

Example

/* Single line comment */
CREATE TABLE test_data (
  value VARCHAR(25) NOT NULL PRIMARY KEY
);

/*
Multi-line
comment
*/

-- Sql-style comment

-- Placeholder
INSERT INTO ${tableName} (value) VALUES ('Mr. T');

CREATE TABLE customers(name VARCHAR, address VARCHAR);
CREATE TABLE orders(address VARCHAR, customer_name VARCHAR);
CREATE TRIGGER update_customer_address UPDATE OF address ON customers
  BEGIN
    UPDATE orders SET address = new.address WHERE customer_name = old.name;
  END;

Limitations

  • No concurrent migration as SQLite does not support SELECT ... FOR UPDATE locking
  • No support for multiple schemas or changing the current schema, as SQLite doesn’t support schemas
  • No support for CREATE TRANSACTION and COMMIT statements within a migration, as SQLite doesn’t support nested transactions

Firebird ➡️