Skip to main content

SQLAlchemy 1.4 / 2.0 support for aiohttp.

Project description

Release Python versions Downloads count Build status Test coverage Codacy Badge 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 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
from aiohttp_sqlalchemy import sa_session

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(MyModel())
        result = await db_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()

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

Uploaded Python 3

File details

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

File metadata

  • Download URL: aiohttp-sqlalchemy-0.17.0.tar.gz
  • Upload date:
  • Size: 7.9 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.17.0.tar.gz
Algorithm Hash digest
SHA256 649ff861a03e4eebf17f30da034fcd57adb627ca28e8f751b75e1da4adcfd2be
MD5 a9da0289321e478a5c9e313ff8c700fc
BLAKE2b-256 b840a14938c9244c0c368a80accf6babd0ad6450206bd5cdf2c9e68775640fcb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: aiohttp_sqlalchemy-0.17.0-py3-none-any.whl
  • Upload date:
  • Size: 8.4 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.17.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3175872bb86d8b9b3d7c88846830808489b37ccf43961571bafd3fb579f64c1b
MD5 ef33101e919f90f1f42d03bc069e44ee
BLAKE2b-256 8becb2b62aab86c44d96c7958fbdca074d65101b10071511c6260d19414a675f

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