FA3-Datafetch/backend/app/database.py
2026-01-11 21:33:47 +08:00

34 lines
859 B
Python

"""
数据库连接配置 (新架构)
使用 AsyncSession 支持异步操作
"""
import os
from sqlalchemy.ext.asyncio import create_async_engine, AsyncSession, async_sessionmaker
from sqlalchemy.orm import declarative_base
from dotenv import load_dotenv
load_dotenv()
# 数据库连接 URL
DATABASE_URL = f"postgresql+asyncpg://{os.getenv('DB_USER')}:{os.getenv('DB_PASSWORD')}@{os.getenv('DB_HOST')}:{os.getenv('DB_PORT')}/{os.getenv('DB_NAME')}"
# 创建异步引擎
engine = create_async_engine(
DATABASE_URL,
echo=False, # 设置为 True 可以看到 SQL 日志
future=True
)
# 创建异步 Session 工厂
SessionLocal = async_sessionmaker(
engine,
class_=AsyncSession,
expire_on_commit=False
)
# Dependency
async def get_db():
"""获取数据库会话"""
async with SessionLocal() as session:
yield session