database.py 1.1 KB

12345678910111213141516171819202122232425262728293031323334
  1. # -*- coding: utf-8 -*-
  2. import sqlalchemy
  3. from sqlalchemy import create_engine
  4. from sqlalchemy.ext.declarative import declarative_base
  5. from sqlalchemy.orm import sessionmaker
  6. from config import settings
  7. if sqlalchemy.__version__ >= '1.4':
  8. mysql_engine_url = sqlalchemy.engine.URL.create(**settings.mysql_dwd_config)
  9. mysql_engine_url = mysql_engine_url.update_query_dict({'charset': 'utf8mb4'})
  10. else:
  11. mysql_engine_url = '{drivername}://{username}:{password}@{host}:{port}/{database}?charset=utf8mb4'.format(**settings.mysql_dwd_config)
  12. engine = create_engine(mysql_engine_url, echo=False, pool_size=100, pool_recycle=3600, pool_pre_ping=True)
  13. SessionLocal = sessionmaker(bind=engine)
  14. Base = declarative_base()
  15. # Dependency
  16. def get_db():
  17. try:
  18. db = SessionLocal()
  19. yield db
  20. finally:
  21. db.close()
  22. def get_db_local():
  23. return SessionLocal()
  24. #from database import engine
  25. #from models.oneshare_base import Base
  26. #from models.knowledge_base import Base
  27. #
  28. # #使用Base的metadata和engine来创建所有表
  29. #Base.metadata.create_all(bind=engine)