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

This version

0.3.6

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.3.6.tar.gz (13.8 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.3.6-py3-none-any.whl (15.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: rb_commons-0.3.6.tar.gz
  • Upload date:
  • Size: 13.8 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.3.6.tar.gz
Algorithm Hash digest
SHA256 77f886e01ca5cee54cc8d00e81670aabde09a7ab4bbfee607a17ad1167586d04
MD5 6ab2b92d8d067814c741d617826065b5
BLAKE2b-256 9ed65498efb67b26689d6c058bc5b190ec90c5be325b67dcf94cbdb57ce5f0f3

See more details on using hashes here.

File details

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

File metadata

  • Download URL: rb_commons-0.3.6-py3-none-any.whl
  • Upload date:
  • Size: 15.0 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.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 83b56dcd57812daed5b282f3768bb6ce9dd566248c8863bee12fb2a27d0aec1d
MD5 d161aa1c2878e340db07a627ce89e04b
BLAKE2b-256 9d697861f98c1a2c7676fb8f99803af3d70469a928054cb0efc980cc0d201013

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