No project description provided
Project description
Asyncio Dead Easy Sql API
AIODesa is for simple data access and definition for your python projects
AIODesa simplifies async SQLite database management for your projects. It provides a convenient wrapper around Asiosqlite, allowing easy definition of table and record schemas using Python's dataclasses. Define SQL tables and records effortlessly with AIODesa using a single data class, a tuple of data classes, or a .py file with dataclasses.
AIODesa aims to make defining SQL tables and records easy by utilizing dataclasses to define schemas of tables and records. Table and record schemas can be defined with a single data class, a tuple of multiple data classes, or a .py file with dataclasses defined inside.
For example, define your table schemas in schemas.py
Import db from the package and run with asyncio
main.py
from Database import Db
import asyncio
async def main():
schema_file = "table_schemas.py"
path_to_generate_db = "database.sqlite3"
async with Db(path_to_generate_db) as db:
await db.read_table_schemas(schema_file)
asyncio.run(main())
Tables are automatically generated
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
Sample API usage:
from dataclasses import dataclass
from Database import Db
import asyncio
async def main():
@dataclass
class Table:
username: str
credits: int
table_name: str = "table 1"
schema = Table
async with Db("database.sqlite3") as db:
await db.read_table_schemas(schema)
asyncio.run(main())
Project details
Release history Release notifications | RSS feed
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.1.0.tar.gz
(3.8 kB
view hashes)