Repository and Django-like QuerySet layers for SQLAlchemy with async support
Project description
📦 sqlalchemy-repository
Django-like Repository & QuerySet layer for SQLAlchemy (async-first)
sqlalchemy-repository brings a familiar, expressive, and powerful QuerySet API on top of SQLAlchemy, inspired by Django ORM — but designed for modern async Python.
It helps you write cleaner, composable database logic with support for:
- 🔍 Django-style filtering (
Q,F) - 🔗 Relation traversal via
__syntax - 📊 Aggregations (
Count,Min,Max, etc.) - ⚡ Async-first design
- 🧱 Repository patterns
- 🧠 Type-safe and extensible
🚀 Features
-
QuerySet API
await repo.objects.filter(Q(price__gt=100) & Q(active=True)).all()
-
Django-style lookups
Q(name__icontains="bmw") Q(category__parent__id=1)
-
F expressions (field references)
await repo.objects.update(price=F("price") * 1.1)
-
Aggregations
await repo.objects.annotate(total=Count("id"), max_price=Max("price"))
-
Annotations
await repo.objects.annotate(total=F("qty") * F("unit_price"))
-
Async support (SQLAlchemy 2.0+)
-
Composable query expressions
-
Repository pattern abstraction
📦 Installation
pip install sqlalchemy-repository
⚙️ Requirements
- Python 3.11+
- SQLAlchemy 2.0+
🏗 Basic Usage
Define repository
from sqlalchemy_repository import BaseRepository
class ProductRepository(BaseRepository[Product]):
model = Product
Querying
products = await repo.objects.filter(
Q(price__gt=100),
Q(category__name="Engine")
).order_by("-price").all()
Get single object
product = await repo.objects.get(id=1)
Create
await repo.create(
name="Brake Pad",
price=50
)
Update with F expressions
await repo.objects.filter(id=1).update(
price=F("price") * 1.2
)
Delete
await repo.objects.filter(price__lt=10).delete()
🔗 Relationships via __
await repo.objects.filter(
category__parent__name="Auto Parts"
)
No manual joins needed — handled internally.
🔍 Q Expressions
from sqlalchemy_repository import Q
query = Q(price__gt=100) & (Q(stock__lt=5) | Q(discount=True))
await repo.objects.filter(query).all()
🧮 Aggregations
from sqlalchemy_repository import Count, Max
result = await repo.objects.annotate(
total=Count("id"),
max_price=Max("price")
)
🏷 Annotations
qs = repo.objects.annotate(
total_price=F("quantity") * F("unit_price")
)
data = await qs.all()
🛠 Development
Install dev dependencies:
pip install -e .[dev]
Run linters:
ruff check .
mypy .
🤝 Contributing
Contributions are welcome.
- Fork the repo
- Create a feature branch
- Write tests
- Open a PR
📄 License
MIT License
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 sqlalchemy_repository-1.1.4.tar.gz.
File metadata
- Download URL: sqlalchemy_repository-1.1.4.tar.gz
- Upload date:
- Size: 11.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5e630948e8eb262f6719c092d8fb4ad65229eca4a74c6494b1595a39c8cf2d13
|
|
| MD5 |
002993764d28e84be119044fbd50d797
|
|
| BLAKE2b-256 |
2f8c7019e42f0cde32af487121ae0f58699278278270c848b38851bf03452e97
|
Provenance
The following attestation bundles were made for sqlalchemy_repository-1.1.4.tar.gz:
Publisher:
release.yml on AstralMortem/sqlalchemy-repository
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
sqlalchemy_repository-1.1.4.tar.gz -
Subject digest:
5e630948e8eb262f6719c092d8fb4ad65229eca4a74c6494b1595a39c8cf2d13 - Sigstore transparency entry: 1461228152
- Sigstore integration time:
-
Permalink:
AstralMortem/sqlalchemy-repository@ff43c2d4715336b08e1f1bbe3c2654848b280cef -
Branch / Tag:
refs/tags/v1.1.4 - Owner: https://github.com/AstralMortem
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@ff43c2d4715336b08e1f1bbe3c2654848b280cef -
Trigger Event:
push
-
Statement type:
File details
Details for the file sqlalchemy_repository-1.1.4-py3-none-any.whl.
File metadata
- Download URL: sqlalchemy_repository-1.1.4-py3-none-any.whl
- Upload date:
- Size: 15.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b9b3a24f02d0bbe9f9fe0df1c7ffebe2209f54a47d05219f7cc7ac99a028ab4c
|
|
| MD5 |
c5acfb03eb56bf775ece16f364f47b62
|
|
| BLAKE2b-256 |
d3861fc90ec73016e22be16d27c1024f5a934427f9da465a1061917dfde9c789
|
Provenance
The following attestation bundles were made for sqlalchemy_repository-1.1.4-py3-none-any.whl:
Publisher:
release.yml on AstralMortem/sqlalchemy-repository
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
sqlalchemy_repository-1.1.4-py3-none-any.whl -
Subject digest:
b9b3a24f02d0bbe9f9fe0df1c7ffebe2209f54a47d05219f7cc7ac99a028ab4c - Sigstore transparency entry: 1461228607
- Sigstore integration time:
-
Permalink:
AstralMortem/sqlalchemy-repository@ff43c2d4715336b08e1f1bbe3c2654848b280cef -
Branch / Tag:
refs/tags/v1.1.4 - Owner: https://github.com/AstralMortem
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@ff43c2d4715336b08e1f1bbe3c2654848b280cef -
Trigger Event:
push
-
Statement type: