Skip to main content

Commons of project and simplified orm based on sqlalchemy.

Project description

RB-Commons

RB-Commons is a lightweight async Python library that simplifies database operations through a clean manager interface built on top of SQLAlchemy's async capabilities. It provides a robust foundation for handling common database operations while maintaining full type safety through Python's typing system.

Features

Async-First Design

  • Built on top of SQLAlchemy's async functionality
  • Efficient handling of async database operations
  • Proper transaction and session management
  • Type-safe operations with Generic types

Core Functionality

  • CRUD Operations: Complete set of Create, Read, Update, and Delete operations
  • Flexible Filtering: Support for dynamic query filtering
  • Instance Management: Both instance-level and query-level updates
  • Error Handling: Comprehensive error handling with custom exceptions
  • Transaction Safety: Automatic rollbacks on failures

Installation

pip install rb-commons

Quick Start

from sqlalchemy.ext.asyncio import AsyncSession, create_async_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String
from rb_commons.orm import BaseManager

# Define your model
Base = declarative_base()

class User(Base):
    __tablename__ = 'users'
    
    id = Column(Integer, primary_key=True)
    name = Column(String)
    email = Column(String)

# Create your manager
class UserManager(BaseManager[User]):
    model = User

# Usage in async context
async def main():
    # Setup database connection
    engine = create_async_engine("postgresql+asyncpg://user:pass@localhost/db")
    async with AsyncSession(engine) as session:
        # Initialize manager
        user_manager = UserManager(session)
        
        # Create user
        user = await user_manager.create(
            name="John Doe",
            email="john@example.com"
        )
        
        # Get user
        user = await user_manager.get(id=1)
        
        # Filter users
        users = await user_manager.filter(name="John Doe")
        
        # Update user by filters
        updated_user = await user_manager.update_by_filters(
            filters={"id": 1},
            name="Jane Doe"
        )
        
        # Delete user
        success = await user_manager.delete(id=1)

Core Operations

Get and Filter

# Get single instance (returns Optional[ModelType])
user = await user_manager.get(id=1)

# Filter multiple instances (returns List[ModelType])
active_users = await user_manager.filter(is_active=True)

# Check existence
exists = await user_manager.is_exists(email="john@example.com")

Create

try:
    user = await user_manager.create(
        name="John Doe",
        email="john@example.com"
    )
except DatabaseException as e:
    print(f"Database error: {e}")
except InternalException as e:
    print(f"Internal error: {e}")

Update

RB-Commons provides three different ways to update records:

# 1. Update by filters - updates records matching filters and returns updated instance
updated_user = await user_manager.update_by_filters(
    filters={"id": 1},
    name="New Name"
)

# 2. Update instance with specific fields
user = await user_manager.get(id=1)
if user:
    updated_user = await user_manager.update(
        instance=user,
        name="New Name"
    )

# 3. Save modified instance
user = await user_manager.get(id=1)
if user:
    user.name = "New Name"
    saved_user = await user_manager.save(user)

Delete

# Delete by ID
success = await user_manager.delete(id=1)

# Delete by filters
success = await user_manager.delete(email="old@example.com")

# Bulk delete
deleted_count = await user_manager.bulk_delete(is_active=False)

Error Handling

RB-Commons provides custom exceptions for better error handling:

  • DatabaseException: For SQLAlchemy and database-related errors
  • InternalException: For internal operation errors
try:
    user = await user_manager.create(name="John")
except DatabaseException as e:
    # Handle database errors (e.g., constraint violations)
    print(f"Database error: {e}")
except InternalException as e:
    # Handle internal errors
    print(f"Internal error: {e}")

Method Return Types

  • get(): Optional[ModelType]
  • filter(): List[ModelType]
  • create(): ModelType
  • delete(): bool | None
  • bulk_delete(): int
  • update(): Optional[ModelType]
  • update_by_filters(): Optional[ModelType]
  • save(): Optional[ModelType]
  • is_exists(): bool

Best Practices

  1. Choose the Right Update Method:
    • Use update_by_filters() for query-based updates
    • Use update() for updating specific fields of an instance
    • Use save() for saving modified instances
  2. Always Use Async Context: The library is designed for async operations, ensure you're running within an async context
  3. Session Management: Properly manage your database sessions using async context managers
  4. Error Handling: Implement proper error handling using the provided exception classes
  5. Type Safety: Utilize the generic typing system for better IDE support and type safety

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License - see the LICENSE file for details.

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

rb_commons-0.4.9.tar.gz (14.9 kB view details)

Uploaded Source

Built Distribution

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

rb_commons-0.4.9-py3-none-any.whl (16.2 kB view details)

Uploaded Python 3

File details

Details for the file rb_commons-0.4.9.tar.gz.

File metadata

  • Download URL: rb_commons-0.4.9.tar.gz
  • Upload date:
  • Size: 14.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for rb_commons-0.4.9.tar.gz
Algorithm Hash digest
SHA256 f65a6f7bb2273ea92cc35bdd8db22392f79e34e00125c1d1a527441ce1ce72c6
MD5 dcc4822bf3d096d2d537982a1e42e377
BLAKE2b-256 ea1e2cda9214e403b624a8adf03aa8f41dc3c5bf223dc542993e46c8023ab063

See more details on using hashes here.

File details

Details for the file rb_commons-0.4.9-py3-none-any.whl.

File metadata

  • Download URL: rb_commons-0.4.9-py3-none-any.whl
  • Upload date:
  • Size: 16.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for rb_commons-0.4.9-py3-none-any.whl
Algorithm Hash digest
SHA256 1496eef180b56eb91defe86c88cc5298afb0c39b562dd4454a844315d69ebd64
MD5 62fdc3ec8509469fafe4b6c7d9b7016a
BLAKE2b-256 9745de7510fd26aac5a97f6b04104983e462e1eee7b1c1f408a15aa55184256f

See more details on using hashes here.

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