Skip to main content

Provide concise, Pythonic query syntax for SQLAlchemy

Project description

The pythonic_sqlalchemy_query module provides concise, Pythonic query syntax for SQLAlchemy. For example, these two queries produce identical results:

pythonic_query = session.User['jack'].addresses['jack@google.com']
traditional_query = (
    # Ask for the Address...
    session.query(Address).
    # by querying a User named 'jack'...
    select_from(User).filter(User.name == 'jack').
    # then joining this to the Address 'jack@google.com`.
    join(Address).filter(Address.email_address == 'jack@google.com')

Installation

pip install pythonic_sqlalchemy_query

Use with SQLAlchemy

For most cases:

from pythonic_sqlalchemy_query import QueryMakerSession

# Construct an engine as usual.
engine = create_engine(...)
# Create a session aware of this module.
Session = sessionmaker(bind=engine, class_=QueryMakerSession)
session = Session()

# After defining some declarative classes, query away:
for result in session.User['jack'].addresses:
    # Do some processing on result...

The examples provide full, working code.

Use with Flask-SQLAlchemy

For most cases:

from pythonic_sqlalchemy_query.flask import SQLAlchemyPythonicQuery

app = Flask(__name__)
db = SQLAlchemyPythonicQuery(app)

# After defining some declarative classes, query away:
for result in User['jack'].addresses:
    # Do some processing on result...

The examples provide full, working code.

Documentation

See the pythonic_sqlalchemy_query module.

License

This software is distributed under the terms of the MIT license.

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

pythonic_sqlalchemy_query-1.1.1.tar.gz (10.0 kB view details)

Uploaded Source

Built Distribution

pythonic_sqlalchemy_query-1.1.1-py2.py3-none-any.whl (18.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pythonic_sqlalchemy_query-1.1.1.tar.gz.

File metadata

File hashes

Hashes for pythonic_sqlalchemy_query-1.1.1.tar.gz
Algorithm Hash digest
SHA256 c2478de9a7c7156170293db0f0b5eb01fe570e8a94959eb3ff98a3274bea41bd
MD5 eaf2b699d2ea7889f615935b74d0c7fd
BLAKE2b-256 6bc93d1a2c246cdc8731a69183328807421eceafde16ffbaf6ba0c80a3b31821

See more details on using hashes here.

File details

Details for the file pythonic_sqlalchemy_query-1.1.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pythonic_sqlalchemy_query-1.1.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 7e783c52ea7a801f28415e67b00c1f4d09e38c5dfa96e3db10dc204158953aa1
MD5 84b7b58215ab4fb8ce6f7fd6e7e4c7f1
BLAKE2b-256 9645a1e1750dad23b0612bfc6a68939a360e10b4be1b646ea886274cfc31ebf7

See more details on using hashes here.

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