Files
Kevin 1af442481e 重组为 backend/clients/docs 三层结构,并清理 git 污染。
将后端迁入 backend/,完善根目录 .gitignore,删除误提交的 .mypy_cache 缓存文件。

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-05-21 16:02:25 +08:00

68 lines
2.0 KiB
Python
Executable File
Raw Permalink Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
"""Alembic environment.
开发与生产均通过 `alembic upgrade head` 应用表结构;应用启动时不再自动建表。
本文件读取 `app.config.settings`,把 asyncpg URL 转为同步
``postgresql+psycopg://``psycopg3供 Alembic 使用(仅迁移期间)。
需安装 `psycopg` 包,见 `pyproject.toml`。
"""
from __future__ import annotations
from logging.config import fileConfig
from alembic import context
from sqlalchemy import engine_from_config, pool
from app.config import settings
import app.db.models # noqa: F401 - register ORM tables on Base.metadata
from app.db.base import Base
alembic_config = context.config
if alembic_config.config_file_name is not None:
fileConfig(alembic_config.config_file_name)
target_metadata = Base.metadata
def _sync_database_url() -> str:
"""把 asyncpg URL 转为同步 psycopg3 URL避免 Alembic 强依赖 async 驱动。"""
url = settings.sqlalchemy_database_url
return url.replace("postgresql+asyncpg://", "postgresql+psycopg://", 1)
def run_migrations_offline() -> None:
context.configure(
url=_sync_database_url(),
target_metadata=target_metadata,
literal_binds=True,
dialect_opts={"paramstyle": "named"},
)
with context.begin_transaction():
context.run_migrations()
def run_migrations_online() -> None:
config_section = alembic_config.get_section(alembic_config.config_ini_section) or {}
config_section["sqlalchemy.url"] = _sync_database_url()
connectable = engine_from_config(
config_section,
prefix="sqlalchemy.",
poolclass=pool.NullPool,
)
with connectable.connect() as connection:
context.configure(
connection=connection,
target_metadata=target_metadata,
compare_type=True,
)
with context.begin_transaction():
context.run_migrations()
if context.is_offline_mode():
run_migrations_offline()
else:
run_migrations_online()