sqldiff(1) | General Commands Manual | sqldiff(1) |
sqldiff - sqlite3 database difference utility
sqldiff [options] database1.sqlite database2.sqlite
The sqldiff binary is a command-line utility program that displays the differences between SQLite databases. The usual output is an SQL script that will transform database1.sqlite (the "source" database) into database2.sqlite (the "destination" database).
The sqldiff utility works by finding rows in the source and destination that are logical "pairs". The default behavior is to treat two rows as pairs if they are in tables with the same name and they have the same rowid, or in the case of a WITHOUT ROWID table if they have the same PRIMARY KEY. Any differences in the content of paired rows are output as UPDATEs. Rows in the source database that could not be paired are output as DELETEs. Rows in the destination database that could not be paired are output as INSERTs.
The --primarykey flag changes the pairing algorithm slightly so that the schema-declared PRIMARY KEY is always used for pairing, even on tables that have a rowid. This is often a better choice for finding differences, however it can lead to missed differences in the case of rows that have one or more PRIMARY KEY columns set to NULL.
The sqldiff utility is unable to compute differences for rowid tables for which the rowid is inaccessible. An example of a table with an inaccessible rowid is:
CREATE TABLE inaccessible_rowid(
"rowid" TEXT,
"oid" TEXT,
"_rowid_" TEXT );
The sqldiff utility does not (currently) display differences in TRIGGERs or VIEWs.
By default, differences in the schema or content of virtual tables are not reported on.
However, if a virtual table implementation creates real tables (sometimes referred to as "shadow" tables) within the database to store its data in, then sqldiff.exe does calculate the difference between these. This can have surprising effects if the resulting SQL script is then run on a database that is not exactly the same as the source database. For several of SQLite's bundled virtual tables (FTS3, FTS5, rtree and others), the surprising effects may include corruption of the virtual table content.
If the --vtab option is passed to sqldiff, then it ignores all underlying shadow tables belonging to an FTS3, FTS5 or rtree virtual table and instead includes the virtual table differences directly.
2018-05-10 |