from sqlalchemy import create_engine from sqlalchemy.orm import sessionmaker, Session from models import Base import os # 数据库配置 # 确保 data 目录存在 DATA_DIR = os.path.join(os.path.dirname(os.path.dirname(__file__)), 'data') os.makedirs(DATA_DIR, exist_ok=True) # 数据库文件路径 DB_PATH = os.path.join(DATA_DIR, 'worklist.db') DATABASE_URL = os.getenv('DATABASE_URL', f'sqlite:///{DB_PATH}') # 创建引擎 engine = create_engine( DATABASE_URL, connect_args={"check_same_thread": False} if DATABASE_URL.startswith('sqlite') else {}, echo=False ) # 创建会话工厂 SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine) def init_db(): """初始化数据库""" Base.metadata.create_all(bind=engine) def get_db(): """获取数据库会话的依赖函数""" db = SessionLocal() try: yield db finally: db.close()