SQLite Tutorial on SQLite VACUUM

vacuum command cleans the main database by copying its contents to a temporary database file and reloading the original database file from the copy. this eliminates free pages, aligns table data to be contiguous, and otherwise cleans up the database file structure.

vacuum command may change the rowid of entries in tables that do not have an explicit integer primary key. the vacuum command only works on the main database. it is not possible to vacuum an attached database file.

vacuum command will fail if there is an active transaction. vacuum command is a no-op for in-memory databases. as the vacuum command rebuilds the database file from scratch, vacuum can also be used to modify many database-specific configuration parameters.

manual vacuum

following is a simple syntax to issue a vacuum command for the whole database from command prompt −

$sqlite3 database_name "vacuum;"

you can run vacuum from sqlite prompt as well as follows −

sqlite> vacuum;

you can also run vacuum on a particular table as follows −

sqlite> vacuum table_name;

auto-vaccum

sqlite auto-vacuum does not do the same as vacuum rather it only moves free pages to the end of the database thereby reducing the database size. by doing so it can significantly fragment the database while vacuum ensures defragmentation. hence, auto-vacuum just keeps the database small.

you can enable/disable sqlite auto-vacuuming by the following pragmas running at sqlite prompt −

sqlite> pragma auto_vacuum = none; -- 0 means disable auto vacuum
sqlite> pragma auto_vacuum = full; -- 1 means enable full auto vacuum
sqlite> pragma auto_vacuum = incremental; -- 2 means enable incremental vacuum

you can run the following command from the command prompt to check the auto-vacuum setting −

$sqlite3 database_name "pragma auto_vacuum;"