Skip to main content

AIODesa offers a straightforward and 100% Python interface for managing asynchronous data access. By leveraging Python's built-ins and standard library, it seamlessly wraps around AioSqlite, providing a hassle-free experience. With AIODesa, you can define, generate, and commit data effortlessly, thanks to shared objects for tables and records.

Project description

Asyncio Dead Easy Sql API

MyPy Pytest Code Style Pylint Flake8 Read The Docs Changie Logs

Simplify Your Personal Projects with AIODesa

Are you tired of the hassle of setting up complex databases for small scale applications and personal projects? Designed to streamline monotony, AIODesa makes managing asynchronous database access easy. Perfect for smaller-scale applications where extensive database operations are not a priority.

No need to write even a single line of raw SQL.

A straightforward and 100% Python interface for managing asynchronous database API's by leveraging Python's built-ins and standard library. It wraps around AioSqlite, providing a hassle-free experience to define, generate, and commit data effortlessly, thanks to shared objects for tables and records.

Ideal for Personal Projects

AIODesa is specifically crafted for simpler projects where database IO is minimal. It's not intended for heavy production use but rather serves as an excellent choice for personal projects that require SQL structured data persistence without the complexity of a full-scale database setup. SQLite is leveraged here, meaning youre free to use other SQLite drivers to consume and transform the data if your project outgrows AIODesa.

Read the docs

AIODesa

Usage

Install via pip

pip install aiodesa

Sample API usage:

from aiodesa import Db
import asyncio
from dataclasses import dataclass
from aiodesa.utils.tables import ForeignKey, UniqueKey, PrimaryKey, set_key


async def main():
	# Define structure for both tables and records
	# Easily define key types
	@dataclass
	@set_key(PrimaryKey("username"), UniqueKey("id"), ForeignKey("username", "anothertable"))
	class UserEcon:
		username: str
		credits: int | None = None
		points: int | None = None
		id: str | None = None
		table_name: str = "user_economy"


	async with Db("database.sqlite3") as db:
		# Create table from UserEcon class
		await db.read_table_schemas(UserEcon)

		# Insert a record
		record = db.insert(UserEcon)
		await record('sockheadrps', id="fffff")

		# Update a record
		record = db.update(UserEcon, column_identifier="username")
		await record('sockheadrps', points=2330, id="1234")
		
		# Find All in a table
		find_all_users = db.find_all(UserEcon)
		all_users = await find_all_users()
		for user in all_users:
			print(user.username)

asyncio.run(main())

Development:

Ensure poetry is installed:

pip install poetry

Install project using poetry

poetry add git+https://github.com/sockheadrps/AIODesa.git
poetry install

create a python file for using AIODesa and activate poetry virtual env to run it

poetry shell
poetry run python main.py

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

aiodesa-0.2.0.tar.gz (9.9 kB view details)

Uploaded Source

Built Distribution

aiodesa-0.2.0-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file aiodesa-0.2.0.tar.gz.

File metadata

  • Download URL: aiodesa-0.2.0.tar.gz
  • Upload date:
  • Size: 9.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.12.1 Linux/6.7.3-200.fc39.x86_64

File hashes

Hashes for aiodesa-0.2.0.tar.gz
Algorithm Hash digest
SHA256 640407956e5c6b7afd2cc917d3414d0c861fa068a92172ee2d2ad0d3f475cac6
MD5 8879881748cde3149d5045a90638f265
BLAKE2b-256 5362f1d08154671f0a454dc60a59d094376534ca8c12046374e33aa93cb932c9

See more details on using hashes here.

File details

Details for the file aiodesa-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: aiodesa-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 9.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.12.1 Linux/6.7.3-200.fc39.x86_64

File hashes

Hashes for aiodesa-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8409893b7148532e5ba2da583839c72a8a8e90e6bd95a321c41b69cf230d7dbf
MD5 850ae6e42ca2ef0dd3b0bed13c0249e4
BLAKE2b-256 e68b69c79e665d0d1b3fb0e6ea3e172fca5f25c97d6243abe801c5c932520a85

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