Flexible immutable entity database
Project description
Savior Database
Embedded schema-less database library backed by LMDB.
Currently in development and not stable yet. The interface and disk format may change in future versions without notice. You probably shouldn't use it to store important data.
Permissively licensed with the ISC License.
Goals
- provide a language-neutral disk format
- utilize LMDB's properties like transactions, append-only writes, and zero-copy reads
- provide intuitive schema-less entity modeling and querying interface
- store an immutable history of all values in the database
Developer Interface
There are a few actions you can perform on entities in a transaction:
- store
- fetch
- update
- query
- delete
An entity is conceptually like a dictionary with attributes and values.
A table is an isolated section of the database for storing entities, usually with a similar set of attributes.
Disk Format
All entities of the same type are stored in one inner LMDB database There is no guarantee that entities have a consistent schema.
Entities are stored on disk as a series of timestamped attribute changes.
- key-value entries have the form
(uuid, timestamp, attribute) -> value uuidis an auto-generated entity IDtimestampis an auto-generated timestamp of when the entry was appendedattributeandvalueare the updated entity key value entries
Data is not modified for updates, only appended to indicate the entity changed.
The storage format version is stored as an integer in a special inner database
named _metadata, at a key named version.
The _metadata table's keys and values are also encoded with MessagePack.
You can access the storage format version via Database.VERSION.
Changelog
This document follows the Keep a Changelog format.
Releases are available on PyPI as savior.
0.2.3 - 2019-09-06
Added
- added
Transaction.deletemethod to permanently remove an entity
0.2.2 - 2019-08-06
Fixed
- fixed bug where
created_atdates were all from the first entity
0.2.1 - 2019-08-06
Changed
- opening a database adds a schema version identifier integer to databases that don't have one
Added
- added
Database.VERSIONfor getting storage format version - added
created_atoption toqueryto add an attribute to entities indicating when they were created
0.2.0 - 2019-07-15
Removed
- removed
Database.open_tablessince tables are now required when opening a database
Changed
- renamed
Transaction.createtoTransaction.storefor consistency withTransaction.fetch - changed
Database.openbehavior to require table names on initialization - changed
Transactionmethods to raise error if a table name is used that was not used to open the database with
0.1.2 - 2019-07-15
Added
Database.create_tablesto create tables in databaseDatabase.open_tablesto open existing tables in databaseDatabase.closeto close database manually
0.1.1 - 2019-07-15
Added
- options for manually closing transactions for when it's not possible to use context managers
0.1.0 - 2019-07-15
Added
- initial schema-less immutable interface over LMDB
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file savior-0.2.3.tar.gz.
File metadata
- Download URL: savior-0.2.3.tar.gz
- Upload date:
- Size: 4.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
98bb0f9409747ad65710444d136e32365291932ca3224d898fe452c747f8ef20
|
|
| MD5 |
916e8b237632463886cf8329f659cd9a
|
|
| BLAKE2b-256 |
fd400e7acf4f6e2cc443ef624f64dc19bb133f3ed03d26ec4f2cc665fca666df
|
File details
Details for the file savior-0.2.3-py3-none-any.whl.
File metadata
- Download URL: savior-0.2.3-py3-none-any.whl
- Upload date:
- Size: 5.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8f9f954c64f093174e2ff8e86232b20c72f2e2951ff2cf1503837cb36ba010ee
|
|
| MD5 |
aab3ed6952d82c27a35173a0d7717abc
|
|
| BLAKE2b-256 |
49b9a66d614b7d0a00fa9c145997c520a020068d5ac1d7e8e9f4089b1e0d666b
|