File size: 888 Bytes
85494ee
 
 
 
 
 
66bebb6
85494ee
 
66bebb6
85494ee
 
 
 
 
 
66bebb6
85494ee
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
# database_sql.py
import os
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from models_sql import Base

# 核心:优先读取环境变量中的 PostgreSQL 数据库连接
SQLALCHEMY_DATABASE_URL = os.environ.get("DATABASE_URL", "sqlite:////tmp/comfy_financial.db")

# 兼容性处理:只有在使用降级的 SQLite 时,才需要 check_same_thread=False
connect_args = {"check_same_thread": False} if "sqlite" in SQLALCHEMY_DATABASE_URL else {}

engine = create_engine(SQLALCHEMY_DATABASE_URL, connect_args=connect_args)
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)

def init_sql_db():
    # 启动时自动检查并在云端(或本地)建立缺失的表
    Base.metadata.create_all(bind=engine)

def get_db():
    db = SessionLocal()
    try:
        yield db
    finally:
        db.close()