Skip to main content

Declare multi-table rules for SQLAlchemy update logic -- 40X more concise, Python for extensibility.

Project description

This package enables you to declare rules that govern SQLAlchemy update transaction logic (multi-table derivations, constraints, and actions such as sending mail or messages).

Logic is stated in Python, and is over an 40X more concise than code.

Features

Logic is declared in Python (example below), and is:

  • Extensible: logic consists of rules (see below), plus standard Python code

  • Multi-table: rules like sum automate multi-table transactions

  • Scalable: rules are pruned and optimized; for example, sums are processed as 1 row adjustment updates, rather than expensive SQL aggregate queries

  • Manageable: develop and debug your rules in IDEs, manage it in SCS systems (such as git) using existing procedures

Example:

The following 5 rules represent the same logic as 200 lines of Python:

https://github.com/valhuber/LogicBank/raw/main/images/example.png

To activate the rules declared above:

LogicBank.activate(session=session, activator=declare_logic)

Depends on:

  • SQLAlchemy

  • Python 3.8

More information:

The github project includes documentation and examples.

Acknowledgements

Many thanks to

  • Tyler Band, for testing and the Banking sample

  • Max Tardiveau, for testing

  • Nishanth Shyamsundar, for testing

Change Log

0.0.6 - Initial Version 0.0.7 - Class Name can differ from Table Name 0.0.8 - Much-reduced pip-install dependencies

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

logicbank-0.0.8.tar.gz (23.2 kB view hashes)

Uploaded Source

Built Distribution

logicbank-0.0.8-py3-none-any.whl (30.6 kB view hashes)

Uploaded Python 3

Supported by

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