chore: 添加数据库资源和需求文档
- 新增数据库连接配置 (db_info) - 添加 DDL 编辑需求文档 - 添加 TODO 待办事项 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
66
team-require/web/ddl-edit.md
Normal file
66
team-require/web/ddl-edit.md
Normal file
@@ -0,0 +1,66 @@
|
||||
# 后端需求 - DDL 编辑功能
|
||||
|
||||
## 问题描述
|
||||
|
||||
前端 Database 页面的 Table Mapping 功能已从"字段映射"改为"DDL 编辑"模式。后端需要支持保存和读取 DDL 数据。
|
||||
|
||||
## 需求
|
||||
|
||||
### 1. 保存 DDL
|
||||
|
||||
前端保存时发送 `ddl` 字段而非 `fields` 字段。
|
||||
|
||||
请求结构:
|
||||
```json
|
||||
{
|
||||
"name": "数据库名",
|
||||
"sub_tables": [
|
||||
{
|
||||
"parent_table": "users",
|
||||
"sub_table_name": "用户表",
|
||||
"sub_table_comment": "用户表",
|
||||
"ddl": "CREATE TABLE users (...)"
|
||||
}
|
||||
]
|
||||
}
|
||||
```
|
||||
|
||||
### 2. 后端处理
|
||||
|
||||
- `CreateSubTableRequest` 已有 `DDL string` 字段(已添加)
|
||||
- `UpdateSubTableRequest` 已有 `DDL string` 字段(已添加)
|
||||
- `UpdateDatabaseRequest` 已有 `SubTables []CreateSubTableRequest` 字段(已添加)
|
||||
|
||||
### 3. Service 层修改
|
||||
|
||||
**sub_table_service.go**:
|
||||
|
||||
1. `Create` 函数 - 添加 DDL 字段赋值:
|
||||
```go
|
||||
info := &model.SubTableInfo{
|
||||
// ... 现有字段
|
||||
DDL: req.DDL,
|
||||
}
|
||||
```
|
||||
|
||||
2. `Update` 函数 - 添加 DDL 更新逻辑:
|
||||
```go
|
||||
// 更新 DDL
|
||||
info.DDL = req.DDL
|
||||
```
|
||||
|
||||
**database_service.go 或 handler**:
|
||||
|
||||
在 `Update` 方法中处理 `SubTables` 字段:
|
||||
- 当前端传入 `sub_tables` 时,需要创建或更新对应的子表记录(包括 DDL)
|
||||
- 遍历 `sub_tables`,调用 `SubTableService.Create` 或 `SubTableService.Update`
|
||||
|
||||
## 影响范围
|
||||
|
||||
- `server/internal/service/sub_table_service.go` - Create/Update 方法
|
||||
- `server/internal/service/database_service.go` 或 handler - Update 方法处理 SubTables
|
||||
|
||||
## 状态
|
||||
|
||||
- [x] 前端修改完成
|
||||
- [x] 后端修改已完成
|
||||
Reference in New Issue
Block a user