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

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

98 lines
3.1 KiB
Python

#!/usr/bin/env python
"""
调试用户更新API
"""
import asyncio
import sys
from pathlib import Path
from datetime import datetime
# 添加项目根目录到 Python 路径
project_root = Path(__file__).parent
sys.path.append(str(project_root))
from sqlalchemy.ext.asyncio import AsyncSession
from app.core.deps import get_db
from app.services.user_service import UserService
from app.schemas.user import UserUpdate
from app.models.user import User
from app.core.logger import logger
async def debug_update():
"""调试更新流程"""
# 获取数据库会话
async for db in get_db():
try:
# 1. 创建服务实例
user_service = UserService(db)
# 2. 获取superadmin用户
print("1. 获取superadmin用户...")
user = await user_service.get_by_username("superadmin")
if not user:
print("用户不存在")
return
print(f"用户ID: {user.id}")
print(f"用户名: {user.username}")
print(f"当前学校: {user.school}")
print(f"当前专业: {user.major}")
# 3. 创建更新数据
print("\n2. 创建更新数据...")
update_data = UserUpdate(
school="北京大学",
major="软件工程",
bio="测试更新"
)
print(f"更新数据: {update_data.model_dump(exclude_unset=True)}")
# 4. 执行更新
print("\n3. 执行更新...")
updated_user = await user_service.update_user(
user_id=user.id,
obj_in=update_data,
updated_by=user.id
)
# 5. 检查更新结果
print("\n4. 更新后的数据:")
print(f"用户ID: {updated_user.id}")
print(f"用户名: {updated_user.username}")
print(f"学校: {updated_user.school}")
print(f"专业: {updated_user.major}")
print(f"个人简介: {updated_user.bio}")
# 6. 再次查询验证
print("\n5. 再次查询验证...")
verified_user = await user_service.get_by_id(user.id)
print(f"验证 - 学校: {verified_user.school}")
print(f"验证 - 专业: {verified_user.major}")
# 7. 检查数据库中的实际值
print("\n6. 检查数据库实际值...")
from sqlalchemy import text
result = await db.execute(
text("SELECT school, major FROM users WHERE id = :user_id"),
{"user_id": user.id}
)
row = result.fetchone()
if row:
print(f"数据库 - 学校: {row[0]}")
print(f"数据库 - 专业: {row[1]}")
except Exception as e:
print(f"错误: {e}")
import traceback
traceback.print_exc()
finally:
await db.close()
break
if __name__ == "__main__":
print("调试用户更新API...")
asyncio.run(debug_update())