Skip to main content

SQLAlchemy 1.4 / 2.0 support for aiohttp.

Project description

Release Python versions Downloads count Build status Test coverage Documentation

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 for 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 aiohttp import web
import aiohttp_sqlalchemy
from aiohttp_sqlalchemy import sa_session
from datetime import datetime
import sqlalchemy as sa
from sqlalchemy import orm


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):
    db_session = sa_session(request)

    async with db_session.begin():
        db_session.add_all([MyModel()])
        stmt = sa.select(MyModel)
        result = await db_session.execute(stmt)
        items = result.scalars()

    data = {}
    for item in items:
        data[item.pk] = item.timestamp.isoformat()

    return web.json_response(data)


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

    aiohttp_sqlalchemy.setup(app, [
        aiohttp_sqlalchemy.bind('sqlite+aiosqlite:///'),
    ])
    await aiohttp_sqlalchemy.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.15.2.tar.gz (6.5 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.15.2-py3-none-any.whl (7.9 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for aiohttp-sqlalchemy-0.15.2.tar.gz
Algorithm Hash digest
SHA256 fac23a5e52af077bad5fa947ca8031631dcb74c89a7555bfc07024a47b5e9342
MD5 a69c83e6830db89a64e7dc2a1210f9d5
BLAKE2b-256 68d7fd5d588392f179f43d0862ac2d421c295c36173b16d003519859f84988d4

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for aiohttp_sqlalchemy-0.15.2-py3-none-any.whl
Algorithm Hash digest
SHA256 9a8285964965d0202d29140a5e49791151d9642323b46ff47469572b16a0c17b
MD5 24b84e66eb388b64b2849442e0a23bd4
BLAKE2b-256 c978cbf510d4e1744950f3dc6b0617f0c2024ad4c00ff5485f382c8e9f54ac0e

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