Skip to content

Release fragmented free space from a SQLite3 database by making the file sparse

License

Notifications You must be signed in to change notification settings

CAFxX/sqlite_sparse

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

44 Commits
 
 
 
 
 
 
 
 

Repository files navigation

sqlite_sparse

A small linux-only utility that turns in-place a SQLite3 file into a sparse file by deallocating all SQLite3 free pages in the file. The filesystem containing the SQLite3 file must support sparse files creation via fallocate(FALLOC_FL_PUNCH_HOLE).

CircleCI

Rationale

VACUUMing a SQLite3 database to release the free pages can take a very long time if the file is big. On the contrary, deallocating the free pages using sqlite_sparse is faster - especially in the common case where the number of used pages is bigger than the number of free pages.

VACUUMing will shrink the database further because it not only drops unused free pages, but it also coalesce partially-used pages in fully-used pages.

Compile

gcc -O2 -o sqlite_sparse sqlite_sparse.c

Usage

# make a backup copy of your database (file.sqlite)
cp file.sqlite file.sqlite.bak

# check integrity of the database, and ensure there are no hot journal/wal
sqlite3 file.sqlite "pragma integrity_check"

# deallocate all free pages
sqlite_sparse file.sqlite

# ensure we did not corrupt the database
sqlite3 file.sqlite "pragma integrity_check"

TODO

  • This is just a PoC; ideally SQLite should learn to do this automatically if supported by the filesystem.
  • Additional platforms: Windows should be doable. Mac OS does not support sparse files so this can't be made to work.
  • Link against sqlite so that integrity checks and backups can be made automatically by sqlite_sparse.

About

Release fragmented free space from a SQLite3 database by making the file sparse

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages