lot_manager/db/session.py

47 lines
955 B
Python
Raw Normal View History

2023-12-02 10:53:31 +08:00
from functools import wraps
from contextlib import contextmanager
2023-12-07 17:12:11 +08:00
from db.base import SessionLocal
2023-12-02 10:53:31 +08:00
from sqlalchemy.orm import Session
@contextmanager
def session_scope() -> Session:
"""上下文管理器用于自动获取 Session, 避免错误"""
session = SessionLocal()
try:
yield session
session.commit()
except:
session.rollback()
raise
finally:
session.close()
def with_session(f):
@wraps(f)
def wrapper(*args, **kwargs):
with session_scope() as session:
try:
result = f(session, *args, **kwargs)
session.commit()
return result
except:
session.rollback()
raise
return wrapper
def get_db() -> SessionLocal:
db = SessionLocal()
try:
yield db
finally:
db.close()
def get_db0() -> SessionLocal:
db = SessionLocal()
return db