2025-09-06 04:10:20 +08:00
|
|
|
# persist-1<persist1@126.com>
|
|
|
|
|
# 原因:将 db.py 改造为模块,移除直接执行入口,修复相对导入问题。
|
|
|
|
|
# 副作用:无
|
|
|
|
|
# 回滚策略:还原此文件。
|
2024-04-06 22:11:10 +08:00
|
|
|
import asyncio
|
2025-09-06 04:10:20 +08:00
|
|
|
import sys
|
|
|
|
|
from pathlib import Path
|
2024-01-14 22:06:31 +08:00
|
|
|
|
2025-09-06 04:10:20 +08:00
|
|
|
# Add project root to sys.path
|
|
|
|
|
project_root = Path(__file__).resolve().parents[1]
|
|
|
|
|
if str(project_root) not in sys.path:
|
|
|
|
|
sys.path.append(str(project_root))
|
2023-07-24 20:59:43 +08:00
|
|
|
|
|
|
|
|
from tools import utils
|
2025-09-06 04:10:20 +08:00
|
|
|
from database.db_session import create_tables
|
2024-04-06 22:11:10 +08:00
|
|
|
|
2025-09-06 04:10:20 +08:00
|
|
|
async def init_table_schema(db_type: str):
|
2024-04-06 22:11:10 +08:00
|
|
|
"""
|
2025-09-06 04:10:20 +08:00
|
|
|
Initializes the database table schema.
|
|
|
|
|
This will create tables based on the ORM models.
|
2025-07-14 03:36:48 +08:00
|
|
|
Args:
|
2025-09-06 04:10:20 +08:00
|
|
|
db_type: The type of database, 'sqlite' or 'mysql'.
|
2025-07-14 03:36:48 +08:00
|
|
|
"""
|
2025-09-06 04:10:20 +08:00
|
|
|
utils.logger.info(f"[init_table_schema] begin init {db_type} table schema ...")
|
|
|
|
|
await create_tables(db_type)
|
|
|
|
|
utils.logger.info(f"[init_table_schema] {db_type} table schema init successful")
|
2023-07-24 20:59:43 +08:00
|
|
|
|
2025-09-06 04:10:20 +08:00
|
|
|
async def init_db(db_type: str = None):
|
|
|
|
|
await init_table_schema(db_type)
|
2024-04-18 22:34:51 +08:00
|
|
|
|
2025-09-06 04:10:20 +08:00
|
|
|
async def close():
|
2025-07-14 03:36:48 +08:00
|
|
|
"""
|
2025-09-06 04:10:20 +08:00
|
|
|
Placeholder for closing database connections if needed in the future.
|
2024-04-18 22:34:51 +08:00
|
|
|
"""
|
2025-09-06 04:10:20 +08:00
|
|
|
pass
|