Files
012-kaopeilian/backend/migrations/versions/add_users_soft_delete.py
111 998211c483 feat: 初始化考培练系统项目
- 从服务器拉取完整代码
- 按框架规范整理项目结构
- 配置 Drone CI 测试环境部署
- 包含后端(FastAPI)、前端(Vue3)、管理端

技术栈: Vue3 + TypeScript + FastAPI + MySQL
2026-01-24 19:33:28 +08:00

37 lines
1.0 KiB
Python

"""add users soft delete columns
Revision ID: add_users_soft_delete
Revises: 20250921_align_schema_to_design
Create Date: 2025-09-22 03:00:00
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision: str = 'add_users_soft_delete'
down_revision: Union[str, None] = '20250921_align_schema_to_design'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
# 为 users 表添加软删除字段
op.add_column('users', sa.Column('is_deleted', sa.Boolean(), nullable=False, server_default='0'))
op.add_column('users', sa.Column('deleted_at', sa.DateTime(), nullable=True))
# 添加索引
op.create_index('idx_users_is_deleted', 'users', ['is_deleted'])
def downgrade() -> None:
# 删除索引
op.drop_index('idx_users_is_deleted', table_name='users')
# 删除字段
op.drop_column('users', 'deleted_at')
op.drop_column('users', 'is_deleted')