Skip to main content

A repository library that wraps SQLAlchemy and provides built-in CRUD and a query DSL.

Project description

Base Repository

Python Coverage License

A repository library that wraps SQLAlchemy and provides built-in CRUD and a query DSL.
Once you inherit from BaseRepository, you can use create/read/update/delete right away.

  • No need to re-implement simple CRUD over and over.
  • If you need custom repo methods, you can add them in your project and extend freely.
  • Supports introducing a Mapper for conversions between Pydantic schemas and SQLAlchemy ORM models.

Supported Dependency Versions

The table below lists the minimum required versions for each supported dependency.

To see more about how to test and the result.

python_version sqlalchemy pydantic
3.10 >= 1.4 >= 1.10
>= 3.13 >= 1.4 >= 2.8, 1.7-1.10

Links


Installation

pip install base-repository

Quick Start

1) Define Filter and Repo

from dataclasses import dataclass
from pydantic import BaseModel
from base_repository import BaseRepoFilter, BaseRepository

# Example: existing SQLAlchemy ORM model and Pydantic schema in your project
class Base(DeclarativeBase):
    pass

class UserModel(Base):
    __tablename__ = "users"

    id: Mapped[int] = mapped_column(primary_key=True)
    name: Mapped[str] = mapped_column(nullable=False)

class UserSchema(BaseModel):
    id: int
    name: str
    model_config = ConfigDict(from_attributes=True)


# What you need to add for Base Repository: Filter + Repo
@dataclass
class UserFilter(BaseRepoFilter):
    id: int | iterable[int] | None = None
    name: str | iterable[str] | None = None

class UserRepo(BaseRepository[UserModel]):
    filter_class = UserFilter
    mapping_schema = UserSchema  # Optional: return Pydantic objects by default

2) Plug in a SessionProvider

Decide how the repository should obtain an AsyncSession.
Recommended: inject a SessionProvider once, so the repo can fetch sessions when needed.

from typing import Protocol
from base_repository import SessionProvider, BaseRepository

# Example SessionProvider implementation
class MysqlSessionProvider(SessionProvider):
    def get_session(self) -> AsyncSession:
        return Mysql.current_session()

BaseRepository.configure_session_provider(MysqlSessionProvider())

Alternatively, you can pass a session directly when creating the repo.

async with AsyncSession(engine) as session:
    repo = UserRepo(session)

3) Use CRUD immediately

repo = UserRepo()

# Create
created = await repo.create({"name": "Alice", "email": "a@test.com"})

# Get one
user = await repo.get(UserFilter(name=["Alice", "Bob"]))
user_orm = await repo.get(UserFilter(name="Alice"), convert_domain=False)

# List (OFFSET paging)
q = (
    repo.list()
        .where(UserFilter(name="A"))
        .order_by(["id"])
        .paging(page=1, size=20)
)
users = await repo.execute(q)

# List (CURSOR paging)
q1 = (
    repo.list()
        .order_by(["id"])
        .with_cursor(None)
        .limit(20)
)
users1 = await repo.execute(q1)

# Update / Delete / Count
cnt = await repo.count(UserFilter(name="Alice"))
updated_rows = await repo.update(UserFilter(name="Bob"), {"email": "bob@new"})
deleted_rows = await repo.delete(UserFilter(name="Alice"))

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

base_repository-0.0.1.tar.gz (5.7 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

base_repository-0.0.1-py3-none-any.whl (5.7 MB view details)

Uploaded Python 3

File details

Details for the file base_repository-0.0.1.tar.gz.

File metadata

  • Download URL: base_repository-0.0.1.tar.gz
  • Upload date:
  • Size: 5.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for base_repository-0.0.1.tar.gz
Algorithm Hash digest
SHA256 e8f0cc9e857398e24d2482fc96021e3c5f642d46b526c3df960878a3133d44cd
MD5 fc11bb4081127cbc4b5062c522eb9d0a
BLAKE2b-256 1fa16abfceb088779922e0ee08edbbd8f269392ad5f328c62bd050db05e9da77

See more details on using hashes here.

Provenance

The following attestation bundles were made for base_repository-0.0.1.tar.gz:

Publisher: publish.yml on 4jades/base-repository

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file base_repository-0.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for base_repository-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c08e1d168ee7f04f37f3c6bf21de792d91e18a0817cf6d523f45ab28bb78dea9
MD5 43d2103c1dc2020d4bd1e696117a505f
BLAKE2b-256 4867f4c2d8b64969d2313f276899219444c54f85e016e764e98d38489fadb2e6

See more details on using hashes here.

Provenance

The following attestation bundles were made for base_repository-0.0.1-py3-none-any.whl:

Publisher: publish.yml on 4jades/base-repository

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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