Skip to main content

SQLAlchemy 1.4 / 2.0 support for aiohttp.

Project description

Read The Docs build Release PyPI downloads count MIT License Python version support GitHub continuous integration codecov.io status for master branch Codacy

SQLAlchemy 1.4 / 2.0 support for AIOHTTP.

The library provides the next features:

  • initializing asynchronous sessions through a middlewares;

  • initializing asynchronous sessions through a decorators;

  • simple access to one asynchronous session by default key;

  • preventing attributes from being expired after commit by default;

  • support different types of request handlers;

  • support nested applications.

Documentation

https://aiohttp-sqlalchemy.readthedocs.io

Installation

pip install aiohttp-sqlalchemy

Simple example

Install aiosqlite for work with sqlite3:

pip install aiosqlite

Copy and paste this code in a file and run:

from datetime import datetime

import sqlalchemy as sa
from aiohttp import web
from sqlalchemy import orm

import aiohttp_sqlalchemy as ahsa

metadata = sa.MetaData()
Base = orm.declarative_base(metadata=metadata)


class MyModel(Base):
    __tablename__ = 'my_table'

    pk = sa.Column(sa.Integer, primary_key=True)
    timestamp = sa.Column(sa.DateTime(), default=datetime.now)


async def main(request):
    sa_session = ahsa.get_session(request)

    async with sa_session.begin():
        sa_session.add(MyModel())
        result = await sa_session.execute(sa.select(MyModel))
        result = result.scalars()

    data = {
        instance.pk: instance.timestamp.isoformat()
        for instance in result
    }
    return web.json_response(data)


async def app_factory():
    app = web.Application()

    ahsa.setup(app, [
        ahsa.bind('sqlite+aiosqlite:///'),
    ])
    await ahsa.init_db(app, metadata)

    app.add_routes([web.get('/', main)])
    return app


if __name__ == '__main__':
    web.run_app(app_factory())

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

aiohttp-sqlalchemy-0.20.0.tar.gz (8.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aiohttp_sqlalchemy-0.20.0-py3-none-any.whl (8.9 kB view details)

Uploaded Python 3

File details

Details for the file aiohttp-sqlalchemy-0.20.0.tar.gz.

File metadata

  • Download URL: aiohttp-sqlalchemy-0.20.0.tar.gz
  • Upload date:
  • Size: 8.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.5 Linux/5.4.0-77-generic

File hashes

Hashes for aiohttp-sqlalchemy-0.20.0.tar.gz
Algorithm Hash digest
SHA256 ead8ff35f9a621c3098994db416decde724f2b3e9c5c1e1ac7b3c9ae0b4385f5
MD5 55f28fd2535febea1faaa1ed9288e535
BLAKE2b-256 6f15d55f64f99c0fc7191c157adb72eab760054ac0f3543e5ae0c9d35a0c9254

See more details on using hashes here.

File details

Details for the file aiohttp_sqlalchemy-0.20.0-py3-none-any.whl.

File metadata

  • Download URL: aiohttp_sqlalchemy-0.20.0-py3-none-any.whl
  • Upload date:
  • Size: 8.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.5 Linux/5.4.0-77-generic

File hashes

Hashes for aiohttp_sqlalchemy-0.20.0-py3-none-any.whl
Algorithm Hash digest
SHA256 33f9608e734d0ebd1b5e3f832f1f6665893e9ace4a18f7d1a3e8a7ac743c2dce
MD5 b9ac03576d9a7ac1250ea724f9207a6c
BLAKE2b-256 32c4df4fd05d22cb727c167244c0ba312afdc640a4ad4521366c75001176d79e

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