Skip to content

Db

SqlalchemyAsyncClient

  • sqlalchemy异步客户端

字段

engine

from sqlalchemy.ext.asyncio import create_async_engine
engine = create_async_engine("sqlite+aiosqlite:///admisadmin.db", future=True)
# engine = create_async_engine("mysql+aiomysql://amisadmin:amisadmin@127.0.0.1:3306/amisadmin?charset=utf8mb4", future=True)
# engine = create_async_engine("postgresql+asyncpg://user:pass@host/dbname", future=True)

session_maker

self.session_maker: sessionmaker = sessionmaker(self.engine, class_=AsyncSession, autoflush=False)

方法:

session_factory

async def session_factory(self) -> AsyncGenerator[AsyncSession, Any]:
    async with self.session_maker() as session:
        yield session

SqlalchemySyncClient

  • sqlalchemy同步客户端

字段

engine

from sqlalchemy import create_engine
engine = create_engine("sqlite+pysqlite:///admisadmin.db", echo=True, future=True)
# engine = create_async_engine("mysql+pymysql://amisadmin:amisadmin@127.0.0.1:3306/amisadmin?charset=utf8mb4", future=True)
# engine = create_async_engine("postgresql+psycopg2://user:pass@host/dbname", future=True)

session_maker

self.session_maker: sessionmaker = sessionmaker(self.engine, autoflush=False)

方法:

session_factory

def session_factory(self) -> Generator[Session, Any, None]:
    session = self.session_maker()
    try:
        yield session
        session.commit()
        finally:
            session.close()