# -*- coding: utf-8 -*- import sqlalchemy from sqlalchemy import create_engine from sqlalchemy.ext.declarative import declarative_base from sqlalchemy.orm import sessionmaker from config import settings mysql_dwd_config = { 'drivername': 'mysql+pymysql', 'username': settings.MYSQL_USER, 'password': settings.MYSQL_PASSWORD, 'host': settings.MYSQL_SERVER, 'port':settings.MYSQL_PORT, 'database': settings.MYSQL_DB_NAME } if sqlalchemy.__version__ >= '1.4': mysql_engine_url = sqlalchemy.engine.URL.create(**mysql_dwd_config) mysql_engine_url = mysql_engine_url.update_query_dict({'charset': 'utf8mb4'}) else: mysql_engine_url = '{drivername}://{username}:{password}@{host}:{port}/{database}?charset=utf8mb4'.format(**mysql_dwd_config) engine = create_engine(mysql_engine_url, echo=False, pool_size=100, pool_recycle=3600, pool_pre_ping=True) SessionLocal = sessionmaker(bind=engine) Base = declarative_base() # Dependency def get_db(): try: db = SessionLocal() yield db finally: db.close() def get_db_local(): return SessionLocal() #from database import engine #from models.oneshare_base import Base #from models.knowledge_base import Base # # #使用Base的metadata和engine来创建所有表 #Base.metadata.create_all(bind=engine)