CRUD tools for working with database via SQLAlchemy.
Project description
DB-First
CRUD tools for working with database via SQLAlchemy.
Features
- CreateMixin, ReadMixin, UpdateMixin, DeleteMixin for CRUD operation for database.
- PaginateMixin for get paginated data from database.
- QueryMaker class for create query 'per-one-model'.
- Marshmallow (https://github.com/marshmallow-code/marshmallow) schemas for validating input data.
- Marshmallow schemas for deserialization SQLAlchemy result object to
dict.
Installation
Recommended using the latest version of Python. DB-First supports Python 3.9 and newer.
Install and update using pip:
$ pip install -U db_first
Example
File with application initialization main.py:
from uuid import UUID
from db_first import BaseCRUD
from db_first.base_model import ModelMixin
from db_first.mixins import CreateMixin
from db_first.mixins import DeleteMixin
from db_first.mixins import PaginationMixin
from db_first.mixins import ReadMixin
from db_first.mixins import UpdateMixin
from marshmallow import fields
from marshmallow import Schema
from sqlalchemy import create_engine
from sqlalchemy.orm import declarative_base
from sqlalchemy.orm import Mapped
from sqlalchemy.orm import mapped_column
from sqlalchemy.orm import Session
engine = create_engine('sqlite://', echo=True, future=True)
session = Session(engine)
Base = declarative_base()
class Items(ModelMixin, Base):
__tablename__ = 'items'
data: Mapped[str] = mapped_column(comment='Data of item.')
Base.metadata.create_all(engine)
class InputSchemaOfCreate(Schema):
data = fields.String()
class InputSchemaOfUpdate(InputSchemaOfCreate):
id = fields.UUID()
class OutputSchema(InputSchemaOfUpdate):
created_at = fields.DateTime()
class ItemController(CreateMixin, ReadMixin, UpdateMixin, DeleteMixin, PaginationMixin, BaseCRUD):
class Meta:
session = session
model = Items
input_schema_of_create = InputSchemaOfCreate
input_schema_of_update = InputSchemaOfUpdate
output_schema_of_create = OutputSchema
output_schema_of_read = OutputSchema
output_schema_of_update = OutputSchema
output_schema_of_paginate = OutputSchema
sortable = ['created_at']
if __name__ == '__main__':
item = ItemController()
first_new_item = item.create(data={'data': 'first'})
print('Item as object:', first_new_item)
second_new_item = item.create(data={'data': 'second'}, jsonify=True)
print('Item as dict:', second_new_item)
first_item = item.read(first_new_item.id)
print('Item as object:', first_item)
first_item = item.read(first_new_item.id, jsonify=True)
print('Item as dict:', first_item)
updated_first_item = item.update(data={'id': first_new_item.id, 'data': 'updated_first'})
print('Item as object:', updated_first_item)
updated_second_item = item.update(
data={'id': UUID(second_new_item['id']), 'data': 'updated_second'}, jsonify=True
)
print('Item as dict:', updated_second_item)
items = item.paginate(sort_created_at='desc')
print('Items as objects:', items)
items = item.paginate(sort_created_at='desc', jsonify=True)
print('Items as dicts:', items)
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
db_first-1.0.0.tar.gz
(11.4 kB
view details)
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 db_first-1.0.0.tar.gz.
File metadata
- Download URL: db_first-1.0.0.tar.gz
- Upload date:
- Size: 11.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
139a2747acc56faa89507c24612a7047916a41a4bcb67f6834553480e6af980f
|
|
| MD5 |
72f3cba3c90863a6e4fef1a68cdd0e11
|
|
| BLAKE2b-256 |
70f3e7f92d4c8b3fcd9eedfd2ff8914398273c32e6ac3c517515a6d4538761a8
|
File details
Details for the file DB_First-1.0.0-py3-none-any.whl.
File metadata
- Download URL: DB_First-1.0.0-py3-none-any.whl
- Upload date:
- Size: 9.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0a62b3524988b7a913b328411315b4e2ee817fc1465be87f423319e2a60fc6eb
|
|
| MD5 |
c36e1f9ea33d18a93e0a2e5d74e46d33
|
|
| BLAKE2b-256 |
333a3e49dc0162222f83d41811f6a20a0054d188cf62ef9b79e6b37a13c7013a
|