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 errorsInternalException: 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():ModelTypedelete():bool | Nonebulk_delete():intupdate():Optional[ModelType]update_by_filters():Optional[ModelType]save():Optional[ModelType]is_exists():bool
Best Practices
- 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
- Use
- Always Use Async Context: The library is designed for async operations, ensure you're running within an async context
- Session Management: Properly manage your database sessions using async context managers
- Error Handling: Implement proper error handling using the provided exception classes
- 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
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 rb_commons-0.5.21.tar.gz.
File metadata
- Download URL: rb_commons-0.5.21.tar.gz
- Upload date:
- Size: 16.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
408914b6094298c4c517437aac3c43d824f50752dc54f01579d8620af86badf3
|
|
| MD5 |
086ac0e236e6e55bce5861b4678d7e3b
|
|
| BLAKE2b-256 |
9553f73fe88f27e442c89d3bb71f756e5226d30167b93a1fdad1f7f50514ffed
|
File details
Details for the file rb_commons-0.5.21-py3-none-any.whl.
File metadata
- Download URL: rb_commons-0.5.21-py3-none-any.whl
- Upload date:
- Size: 18.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5bb3cc5ead576db69d87dd1a820c7650561ee9bda0ef46880a666a2a35bc0824
|
|
| MD5 |
17cb083fe3cbdf337164e24a3d6c73e3
|
|
| BLAKE2b-256 |
ab50125ec3bb676ed1afb8c1cdbf1d02c302b0127820029669d7cca750952333
|