Skip to main content

A small package that binds dataclasses to an sqlite database

Project description

Datalite

Maintainability Test Coverage PyPI version shields.io PyPI license

Datalite is a simple Python package that binds your dataclasses to a table in a sqlite3 database, using it is extremely simple, say that you have a dataclass definition, just add the decorator @datalite(db_name="db.db") to the top of the definition, and the dataclass will now be bound to the file db.db

Download and Install

You can install datalite simply by

pip install datalite

Or you can clone the repository and run

python setup.py

Datalite has no dependencies! As it is built on Python 3.7+ standard library. Albeit, its tests require unittest library.

Datalite in Action

from dataclasses import dataclass
from datalite import datalite


@datalite(db_path="db.db")
@dataclass
class Student:
    student_id: int
    student_name: str = "John Smith"

This snippet will generate a table in the sqlite3 database file db.db with table name student and rows student_id, student_name with datatypes integer and text, respectively. The default value for student_name is John Smith.

##Basic Usage

Entry manipulation

After creating an object traditionally, given that you used the datalite decorator, the object has three new methods: .create_entry(), .update_entry() and .remove_entry(), you can add the object to its associated table using the former, and remove it using the later. You can also update a record using the middle.

student = Student(10, "Albert Einstein")
student.create_entry()  # Adds the entry to the table associated in db.db.
student.student_id = 20 # Update an object on memory.
student.update_entry()  # Update the corresponding record in the database.
student.remove_entry()  # Removes from the table.

But what if you have created your object in a previous session, or wish to remove an object unreachable? ie: If the object is already garbage collected by the Python interpreter? remove_from(class_, obj_id) is a function that can be used for this express purpose, for instance:

remove_from(Student, 2)  # Removes the Student with obj_id 2.

Object IDs are auto-incremented, and correspond to the order the entry were inserted onto the system.

Fetching Records

:warning: Limitation! Fetch can only fetch limited classes correctly: int, float, bytes and str!

Finally, you may wish to recreate objects from a table that already exist, for this purpose we have the module fetch module, from this you can import fetch_from(class_, obj_id) as well as is_fetchable(className, object_id) former fetches a record from the SQL database given its unique object_id whereas the latter checks if it is fetchable (most likely to check if it exists.)

>>> fetch_from(Student, 2)
Student(student_id=10, student_name='Albert Einstein')

We also have four helper methods, fetch_range(class_, range_) and fetch_all(class_) are very similar: the former fetches the records fetchable from the object id range provided by the user, whereas the latter fetches all records. Both return a tuple of class_ objects.

The last two helper methods, fetch_if(class_, condition) fetches all the records of type class_ that fit a certain condition. Here conditions must be written is SQL syntax. For easier, only one conditional checks, there is fetch_equals(class_, field, value) that checks the value of only one field and returns the object whose field equals the provided value.

Pagination

datalite also supports pagination on fetch_if, fetch_all and fetch_where, you can specify page number and element_count for each page (default 10), for these functions in order to get a subgroup of records.

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

datalite-0.5.2.tar.gz (7.4 kB view details)

Uploaded Source

Built Distribution

datalite-0.5.2-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file datalite-0.5.2.tar.gz.

File metadata

  • Download URL: datalite-0.5.2.tar.gz
  • Upload date:
  • Size: 7.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.8

File hashes

Hashes for datalite-0.5.2.tar.gz
Algorithm Hash digest
SHA256 f80fb303f9db1be6e333421954096ab8c55efa20c6b5861827af78011c41767f
MD5 3ab6124a0c4edd2633b0a1328c1cec35
BLAKE2b-256 06d7a7c9ebaaa90dbb89450c63f39f7b80eb245a5d713b57d87fbfcdb4f36ea8

See more details on using hashes here.

File details

Details for the file datalite-0.5.2-py3-none-any.whl.

File metadata

  • Download URL: datalite-0.5.2-py3-none-any.whl
  • Upload date:
  • Size: 9.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.8

File hashes

Hashes for datalite-0.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 53ff857b4dff780afcdf25fa323e97dc0834ceff3d86ee5370bbd2c7dd660c79
MD5 732c34b3232becee1631f9bf8d569e4e
BLAKE2b-256 1a27441c484fa0a2cc241371d8c6b2166a6461c84ddf5d4f7253a5fd1eb1915f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page