11 KiB
11 KiB
表结构查看功能 - 待讨论问题
创建日期:2025-01-28
目的:整理设计文档中需要进一步讨论和明确的问题
一、实现细节待明确
1.1 MongoDB 字段统计实现方式
问题:FIXME标记 - 使用采样统计,默认采样10个文档
需要讨论:
- ✅ 已确定:使用采样统计,默认采样10个文档
- ⚠️ 待明确:
- 采样方式:使用
$sample聚合管道还是find().limit(10)? FIME:sample - 采样数量:10个是否足够?是否需要可配置? FIXME:后期支持可配置
- 性能影响:10个文档的性能如何?是否需要异步加载? FIXME: 全异步
- 前端展示:是否需要显示"基于10个文档采样"的提示?FIXME: 展示
- 采样方式:使用
建议:
- 使用
$sample聚合管道随机采样(更准确) - 默认采样10个文档(性能好,准确性适中)
- 前端明确标注"基于10个文档采样统计"
- 后续可扩展为可配置采样数量(P2)
1.2 触发查看结构(已确定)
触发方式:
- ✅ 点击连接节点:查看连接的数据库列表结构
- ✅ 点击数据库节点:查看数据库的表/集合列表结构
- ✅ 点击表/集合/Key节点:查看具体的表/集合/Key结构
- ✅ 结构信息展示区域自动激活(切换到"结构"Tab并打开)
实现方式:
- 在
handleTreeSelect中,根据节点类型触发table-structure事件 - 事件处理函数自动切换到结果面板的"结构"Tab
- 如果结果面板隐藏,自动显示
1.3 连接树右键菜单实现
问题:如何实现右键菜单触发"查看结构"
需要讨论:
- ⚠️ 待明确:
- Arco Design Tree 组件是否支持右键菜单?
- 如果不支持,是否需要自定义实现?
- 右键菜单的选项有哪些?(查看结构、生成SQL、删除等)
- 菜单位置和样式如何设计?
建议:
- 检查 Arco Design Tree 的右键菜单支持
- 如果不支持,使用
@contextmenu事件自定义菜单 - 菜单选项:查看结构、生成SELECT语句、复制表名(根据节点类型显示不同选项) FIXME: 系统性设计右键菜单补充相关设计文档
1.4 事件名称和参数传递(已确定)
事件名称:✅ table-structure
参数格式:✅ 已确定
emit('table-structure', {
connectionId: number,
database: string,
tableName: string, // 表名/集合名/Key名,对于连接和数据库节点可能为空
dbType: 'mysql' | 'mongo' | 'redis',
nodeType: 'table' | 'collection' | 'key' | 'database' | 'connection'
})
事件处理:
- 在
index.vue中监听table-structure事件 - 调用
useStructureState.loadStructure()加载结构数据 - 自动切换到结果面板的"结构"Tab
详细设计:详见 事件系统设计.md
1.5 结构Tab的显示/隐藏逻辑(已确定)
方案:✅ 方案二 - 始终显示Tab
实现方式:
- "结构"Tab始终显示在结果面板中
- 无数据时显示空状态提示:"请从连接树中选择节点查看结构"
- 有数据时显示结构内容
- 切换连接时,清空结构数据,显示空状态
- 执行SQL时,结构Tab保留,不清空数据
优点:
- ✅ Tab位置固定,用户习惯更好
- ✅ 用户可以随时查看结构,无需先触发查看
空状态设计:
- 显示图标和提示文本
- 提供操作引导:"右键点击连接树节点 → 查看结构"
1.6 多表结构查看场景(已确定)
方案:✅ 方案一 - 单表查看,查看新表时替换当前结构
实现方式:
- 查看新表时,替换当前结构数据
- 结构Tab始终只有一个表的结构
- 简单直接,符合当前设计
未来扩展:
- 方案二:在SQL编辑器Tab区域支持结构Tab
- 右键菜单添加"在新Tab中查看结构"选项
- 在SQL编辑器Tab区域创建结构Tab
- 可以同时查看多个表的结构
- 详见
多表结构查看方案分析.md
当前阶段:
- P0:使用方案一(单表查看)
- P2:考虑实现方案二(SQL编辑器Tab支持结构Tab)
1.6 结构数据与查询结果的冲突
问题:查看结构时执行SQL,如何处理结果展示
需要讨论:
- ⚠️ 待明确:
- 执行SQL时,结构Tab是否自动切换到"结果"Tab?
- 结构数据是否保留,还是清空?
- 用户如何切换回结构Tab?
建议:FIXME: OK
- 执行SQL时,自动切换到"结果"Tab
- 结构数据保留,不清空
- 用户可以手动切换回"结构"Tab继续查看
二、技术实现待明确
2.1 数据缓存策略
问题:结构数据缓存的具体实现
需要讨论:
- ⚠️ 待明确:
- 缓存位置:前端缓存(内存)还是后端缓存?
- 缓存Key:如何生成唯一Key?(connectionId + database + tableName)
- 缓存时间:5分钟是否合适?
- 缓存失效:何时清除缓存?(切换连接、表结构变更后)
建议:OK
- 前端缓存:使用 Map 存储,Key为
${connectionId}-${database}-${tableName} - 缓存时间:5分钟(可配置)
- 缓存失效:切换连接时清除,手动刷新时清除
2.2 权限检查实现
问题:编辑功能如何检查数据库用户权限
需要讨论:
- ⚠️ 待明确:
- 权限检查时机:编辑模式切换时还是保存时?
- 权限检查方式:如何检查 ALTER TABLE、CREATE INDEX 权限?
- 权限不足时的提示:如何友好地提示用户?
建议:OK
- 切换编辑模式时检查权限
- 使用
SHOW GRANTS或尝试执行测试语句检查权限 - 权限不足时禁用编辑功能,显示提示信息
2.3 确认对话框设计
问题:编辑保存时的确认对话框内容
需要讨论:
- ⚠️ 待明确:
- 对话框内容:显示什么信息?(SQL语句、影响范围、风险提示)
- 确认方式:是否需要二次确认?
- 取消操作:取消时如何处理未保存的修改?
建议:OK
- 显示将要执行的 SQL 语句(完整 ALTER TABLE 语句)
- 显示影响范围(修改的字段/索引数量)
- 显示风险提示("此操作不可撤销,请确认")
- 取消时保留编辑内容,不切换回查看模式
2.4 错误处理和重试
问题:加载结构数据失败时的处理
需要讨论:
- ⚠️ 待明确:
- 错误提示:如何显示错误信息?
- 重试机制:是否自动重试?重试次数?
- 部分失败:如果部分数据加载成功,如何处理?
建议:OK
- 显示详细的错误信息(错误类型、错误消息)
- 提供"重试"按钮,不自动重试
- 部分失败时显示已加载的数据,标注失败的部分
三、用户体验待明确
3.1 加载状态展示
问题:加载结构数据时的用户体验
需要讨论:
- ⚠️ 待明确:
- 加载提示:显示什么内容?(Spin、进度条、加载文本)
- 加载时间:如果加载较慢,是否需要超时处理?
- 骨架屏:是否需要使用骨架屏提升体验?
建议:OK
- 使用 Arco Design Spin 组件 + "加载中..."文本
- 设置超时时间(30秒),超时后提示用户
- 大数据集时显示"数据较多,加载可能需要一些时间"的提示
3.2 空状态设计
问题:无结构数据时的展示
需要讨论:
- ⚠️ 待明确:
- 空状态内容:显示什么提示?
- 操作引导:是否需要提供操作按钮?
建议:OK
- 显示空状态图标和提示文本
- 提供"刷新"按钮
- 根据数据库类型显示不同的提示(MySQL/MongoDB/Redis)
3.3 数据刷新策略
问题:何时自动刷新结构数据
需要讨论:
- ⚠️ 待明确:
- 自动刷新:是否需要自动刷新?(表结构可能被其他工具修改)
- 刷新时机:切换Tab时?定时刷新?
- 手动刷新:刷新按钮的位置和样式?
建议:OK
- 不自动刷新(避免不必要的请求)
- 提供手动刷新按钮(在结构Tab工具栏)
- 编辑保存后自动刷新
四、扩展功能待明确
4.1 导出功能实现
问题:导出功能的具体实现方式
需要讨论:
- ⚠️ 待明确:
- 导出格式:SQL、JSON、文本的具体格式?
- 导出内容:导出哪些信息?(字段、索引、注释等)
- 导出方式:下载文件还是复制到剪贴板?
建议:OK
- MySQL:导出为 CREATE TABLE 语句(包含字段、索引、注释)
- MongoDB:导出为 JSON Schema 格式
- Redis:导出为文本格式(Key信息) FIXME: 不需要
- 支持下载文件和复制到剪贴板两种方式
4.2 编辑功能的撤销/重做
问题:编辑模式是否需要撤销/重做功能
需要讨论:
- ⚠️ 待明确:
- 是否需要撤销/重做功能?
- 如果需要,如何实现?(历史记录、操作栈)
- 撤销范围:单次操作还是多次操作?
建议:OK
- P2功能,暂不实现
- 如果需要,使用操作栈记录每次修改
- 支持撤销最近10次操作
五、性能优化待明确
5.1 大数据集处理
问题:字段/索引很多时的性能优化
需要讨论:
- ⚠️ 待明确:
- 分页加载:何时启用分页?(字段数 > 50?)
- 虚拟滚动:是否需要虚拟滚动?
- 懒加载:Tab切换时是否懒加载内容?
建议:OK
- 字段数 > 50 时启用分页(每页20条)
- 使用 Arco Design Table 的内置分页
- Tab切换时懒加载(使用 v-if)
5.2 网络请求优化
问题:如何减少不必要的网络请求
需要讨论:
- ⚠️ 待明确:
- 请求合并:是否可以合并多个请求?
- 请求取消:切换表时是否取消之前的请求?
- 请求去重:相同请求是否去重?
建议:ok
- 使用 AbortController 取消之前的请求
- 相同请求使用缓存,不重复请求
- 字段和索引信息可以合并为一个请求(当前已实现)
六、总结
优先级分类
P0(必须明确):
- ✅ MongoDB字段统计实现方式(已确定:采样10个文档)
- ⚠️ 连接树右键菜单实现方式 FIXME: 做系统性全局设计, 在部分优先功能区开始设计实现,如连接区右键
- ⚠️ 事件名称和参数格式 FIXME: 做个系统性全局设计,简洁易于扩展各种事件都简洁强大,
- ⚠️ 结构Tab显示/隐藏逻辑
- ⚠️ 结构数据与查询结果的冲突处理
P1(重要):
- ⚠️ 数据缓存策略
- ⚠️ 权限检查实现
- ⚠️ 确认对话框设计
- ⚠️ 错误处理和重试
P2(优化):
- ⚠️ 加载状态优化
- ⚠️ 空状态设计
- ⚠️ 导出功能实现
- ⚠️ 大数据集处理
建议讨论顺序
- 首先讨论 P0 问题:这些是核心功能,必须明确
- 然后讨论 P1 问题:影响用户体验,需要仔细设计
- 最后讨论 P2 问题:优化功能,可以后续迭代
下一步:根据讨论结果更新设计文档,明确实现细节。