A simple soft delete implementation for sqlalchemy
Project description
Suave Deletes
Suave Deletes is a Python library that provides a soft delete functionality for SQLAlchemy models.
Soft deletes allow you to mark records as deleted without actually removing them from the database, making it easy to recover or audit data as needed.
Features
- Soft delete: Mark records as deleted without permanently removing them from the database.
- Automatic Query Filtering: Automatically filter out soft-deleted records from your queries.
- Customizable: Configure which models and fields use soft delete functionality.
- Simple Integration: Easily integrate with your existing SQLAlchemy models.
Installation
You can install Suave Deletes using pip:
pip install suave-deletes
Usage
To use Suave Deletes, simply import and apply it to your SQLAlchemy models.
Here is a basic example:
Configuration
from sqlalchemy import create_engine
from suave_deletes.session import create_suave_delete_session
def create_session():
engine = create_engine(
"Your database URI"
)
current_session = create_suave_delete_session(engine)
with current_session() as session:
yield session
Implementation
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String
from suave_deletes.mixins import SuaveDeleteMixin
from suave_deletes.sessions import create_suave_delete_session
DeclarativeBase = declarative_base()
session = create_suave_delete_session()
class Base(DeclarativeBase, SuaveDeleteMixin):
deleted_at = mapped_column(DateTime, default=None)
class MyModel(Base):
__tablename__ = 'my_model'
id = Column(Integer, primary_key=True)
name = Column(String)
# Creates instance
obj = MyModel(name="example")
session.add(obj)
session.commit()
# Soft delete the instance
session.delete(obj)
session.commit()
# Query only non-deleted records
non_deleted_records = session.query(MyModel).all()
# Query all records, including soft deleted ones
all_records = session.query(MyModel).with_deleted_at().all()
Contributing
Contributions are welcome! If you find a bug or have a feature request, please open an issue on GitHub. If you would like to contribute code, please fork the repository and submit a pull request.
License
This project is licensed under the MIT License. See the LICENSE file for details.
Acknowledgments
Thanks to the SQLAlchemy community for their excellent library and documentation.
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
Hashes for suave_deletes-0.1.5-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c49335cb2ae42ac022b9442c058ecb3bfa583d75f7ea4bb2560c5e21931ad2c9 |
|
MD5 | af6588d00ebf4c52f7055ba498059c90 |
|
BLAKE2b-256 | 35da1c1305d7765d0089914e892ef35148781017ec75b8bb91ad1ada37d7a301 |