1
0
mirror of https://gitlab.com/MoonTestUse1/AdministrationItDepartmens.git synced 2025-08-14 00:25:46 +02:00
Files
AdministrationItDepartmens/backend/app/database.py
MoonTestUse1 21e4194909 Fix database
2025-01-07 06:46:37 +06:00

34 lines
818 B
Python

"""Database module"""
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker, declarative_base
from typing import Generator
from .core.config import settings
# Create base class for models
Base = declarative_base()
# Create database engine
engine = create_engine(
settings.get_database_url(),
pool_pre_ping=True,
pool_size=5,
max_overflow=10
)
# Create session factory
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
def get_db() -> Generator:
"""Get database session"""
db = SessionLocal()
try:
yield db
finally:
db.close()
def init_db() -> None:
"""Initialize database"""
# Import models here to avoid circular imports
from .db.base import Base # noqa: F811
Base.metadata.create_all(bind=engine)