forked from polka_billy/porridger
begin implementing async
This commit is contained in:
35
back/db.py
35
back/db.py
@ -1,32 +1,21 @@
|
||||
from typing import AsyncGenerator
|
||||
|
||||
from sqlalchemy import create_engine, MetaData
|
||||
# from sqlalchemy.ext.asyncio import AsyncSession, async_sessionmaker, create_async_engine
|
||||
from sqlalchemy.orm import sessionmaker, DeclarativeBase
|
||||
from asyncio import current_task
|
||||
from sqlalchemy.ext.asyncio import AsyncSession, async_scoped_session, create_async_engine
|
||||
from sqlalchemy.orm import sessionmaker
|
||||
from sqlalchemy.ext.declarative import declarative_base
|
||||
|
||||
|
||||
SQLALCHEMY_DATABASE_URL = "sqlite:///./sql_app.db"
|
||||
SQLALCHEMY_DATABASE_URL = 'postgresql+asyncpg://postgres:D560c34V112Ak@localhost/porridger'
|
||||
|
||||
engine = create_engine(
|
||||
SQLALCHEMY_DATABASE_URL, connect_args={"check_same_thread": False}
|
||||
)
|
||||
engine = create_async_engine(SQLALCHEMY_DATABASE_URL, echo=True)
|
||||
|
||||
SessionLocal = sessionmaker(bind=engine, autoflush=True, autocommit=False)
|
||||
SessionLocal = sessionmaker(bind=engine, class_=AsyncSession, expire_on_commit=False)
|
||||
|
||||
database = SessionLocal()
|
||||
async_session = async_scoped_session(SessionLocal, scopefunc=current_task)
|
||||
Base = declarative_base()
|
||||
|
||||
|
||||
# # add your model's MetaData object here
|
||||
# # for 'autogenerate' support
|
||||
# # in your application's model:
|
||||
|
||||
# class Base(DeclarativeBase):
|
||||
# metadata = MetaData(naming_convention={
|
||||
# "ix": "ix_%(column_0_label)s",
|
||||
# "uq": "uq_%(table_name)s_%(column_0_name)s",
|
||||
# "ck": "ck_%(table_name)s_`%(constraint_name)s`",
|
||||
# "fk": "fk_%(table_name)s_%(column_0_name)s_%(referred_table_name)s",
|
||||
# "pk": "pk_%(table_name)s"
|
||||
# })
|
||||
# Создаем таблицы
|
||||
async def init_models():
|
||||
async with engine.begin() as conn:
|
||||
await conn.run_sync(Base.metadata.drop_all)
|
||||
await conn.run_sync(Base.metadata.create_all)
|
Reference in New Issue
Block a user