Files
lms-it-oms/backend/app/database.py

34 lines
843 B
Python

"""Подключение к БД и сессия."""
import logging
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker, declarative_base
from app.config import settings
logger = logging.getLogger(__name__)
engine = create_engine(
settings.database_url,
pool_pre_ping=True,
echo=False,
)
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
Base = declarative_base()
def get_db():
"""Генератор сессии БД для FastAPI."""
db = SessionLocal()
try:
yield db
finally:
db.close()
def init_db():
"""Создание таблиц при старте."""
from app import models # noqa: F401
Base.metadata.create_all(bind=engine)
logger.info("Таблицы БД созданы или уже существуют")