Syngnat
|
90d84da849
|
🐛 fix(oracle): 修复DDL注释拼接缺少分号与换行
- 为 Oracle 建表 DDL 追加注释前补齐语句结束符并保留空行分隔
- 修复 COMMENT ON TABLE/COLUMN 与 CREATE TABLE 粘连导致复制后无法直接执行的问题
- 补充后端 Oracle 建表语句与前端 DDL 格式化回归测试
|
2026-06-24 11:40:18 +08:00 |
|
Syngnat
|
5e15c4dd2d
|
🐛 fix(query-editor): 隐藏 SQL Server 冗余影响行数结果集
|
2026-06-24 00:22:31 +08:00 |
|
Syngnat
|
5493b62bb9
|
🐛 fix(query-editor): 修复 SQL Server 结果消息缩进并校正回归测试
|
2026-06-23 23:42:30 +08:00 |
|
Syngnat
|
6bf05c9ed7
|
🐛 fix(update): 修复桌面端更新安装与重启流程
- macOS 下载完成后改为直接走安装更新链路,不再只打开安装目录
- Windows 更新脚本在重启时显式带上目标工作目录,提升安装后拉起稳定性
- 删除失效的 winget 发布工作流,并补充前端与脚本回归测试
Fixes #585
|
2026-06-23 22:18:07 +08:00 |
|
Syngnat
|
a2c1b4a7d8
|
🐛 fix(query-editor): 修复外部SQL快捷保存失效
- 放宽活跃 QueryEditor 在文档级快捷键目标下的保存触发条件
- 修复桌面端 Ctrl/Cmd+S 事件落到 document 时未真正写盘的问题
- 保持普通查询保存行为不变,并补充外部 SQL 文件快捷保存回归测试
|
2026-06-23 20:18:06 +08:00 |
|
Syngnat
|
07b3b908f9
|
🐛 fix(mongodb): 修复编辑态字符串类型丢失
- 为 MongoDB 编辑态补充字段名驱动的保守类型推断
- 统一 DataGrid 基准数据为类型化值,覆盖 JSON、行编辑和单元格编辑
- 保持 pMid 等普通字符串字段不被误判为 ObjectId
- 补充 Mongo helper、DataViewer 主键定位与 DataGrid 提交回归测试
|
2026-06-23 19:48:43 +08:00 |
|
Syngnat
|
adacf0b5c5
|
✨ feat(connection): 支持生产连接多项保护策略
- 新增数据编辑、结构编辑、脚本执行和数据导入四类连接级保护配置
- 升级生产连接保护弹窗为多选卡片,并修复选项对齐与勾选态显示
- 按保护类型收口 QueryEditor、DataGrid、表设计、导入与同步目标入口
- 后端统一拦截 SQL 或 Mongo 写操作、结果编辑、结构变更和导入写入
- AI 本地工具与 RPC 执行链路透传连接保护配置并复用后端守卫
- 补充多语言文案、定向测试与需求追踪记录
|
2026-06-23 17:42:54 +08:00 |
|
Syngnat
|
b0a9a995fb
|
✨ feat(connection): 新增生产连接只读保护
|
2026-06-23 15:33:11 +08:00 |
|
Syngnat
|
3205d131c9
|
🐛 fix(query-editor): 修复消息结果前缀与复制全选交互
- 统一清洗 SQL Server 消息前缀并覆盖结果刷新与分页回填链路
- 将消息结果区改为只读文本区,补充一键复制入口
- 放行编辑器外可编辑区域的 cmd/ctrl+a,避免消息内容全选被抢占
- 补充结果面板交互与国际化回归,确保构建通过
|
2026-06-23 14:43:13 +08:00 |
|
Syngnat
|
8da8cc7f91
|
🐛 fix(mongodb): 修复 DataGrid 编辑后 BSON 类型丢失
- 为 MongoDB 结果展示、单元格编辑和行编辑接入类型感知格式化与解析
- 支持 ObjectId、日期、Int32、Int64、Double、Decimal128、UUID 等常见类型保真
- 统一 v1/v2 驱动查询结果的 Extended JSON 输出与 ApplyChanges BSON 恢复
- 补充前端提交链路与后端类型转换回归测试
|
2026-06-23 12:14:27 +08:00 |
|
Syngnat
|
bc63311003
|
🐛 fix(oracle): 修复普通查询重复列自动别名缺失
- 在 QueryEditor 查询计划阶段识别显式列与 alias.* 的重复列冲突
- Oracle 执行前自动为冲突显式列补充 _1 风格唯一别名
- 让 locator 与后续追加表达式复用改写后的可执行 SQL
- 补充普通查询重复列自动别名的 Oracle 回归测试
|
2026-06-23 10:46:35 +08:00 |
|
Syngnat
|
3a00ae1f44
|
🔧 chore(wails): 同步数据同步 targetSchema TS 绑定
- 为 sync 请求模型补充 targetSchema 字段映射
- 同步自动生成的 frontend wailsjs models.ts 绑定
- 更新 package.json.md5 生成校验文件
|
2026-06-23 09:55:41 +08:00 |
|
Syngnat
|
e8cad189be
|
🐛 fix(sqlserver): 修复普通查询结果被原生多结果集吃空
- 对只读 SQL 的原生多结果集空返回增加顺序回退兜底
- 避免 optional driver-agent 成功返回空结果时前端只剩日志无结果集
- 补充 SQLServer 读查询空结果回退回归测试
|
2026-06-23 09:46:44 +08:00 |
|
Syngnat
|
495a985ae1
|
🐛 fix(sqlserver): 修复可选驱动查询消息透传缺失
- 为 optional-driver-agent 的 query 和 queryMulti 响应补充 messages 字段
- 在可选驱动 DB 客户端透传 SQL Server 查询提示信息与多结果集
- 补充 agent 与数据库层回归测试并更新 driver agent revision
|
2026-06-23 08:48:42 +08:00 |
|
Syngnat
|
8f1e6cf379
|
⚡️ perf(frontend): 优化长时运行下的搜索与缓存占用
- 为 V2 cmd+k 搜索预建索引并限制初始/宽泛结果数量
- 清理冷数据库树和 DataViewer 长生命周期快照缓存
- 收紧运行时 SQL 日志预算并在 hydration 时压缩旧缓存
|
2026-06-22 22:36:39 +08:00 |
|
Matt Van Horn
|
05e8dab710
|
Merge 0ba2bfe645 into 4999fd544d
|
2026-06-22 00:33:23 -07:00 |
|
Matt Van Horn
|
0ba2bfe645
|
fix(datasource): ClickHouse 22.8 HTTP 握手兼容 displayName 缺失
clickhouse-go 在 HTTP 握手阶段执行 SELECT displayName(), version(),
revision(), timezone(),而 ClickHouse 22.8 没有 displayName() 函数,
返回 Code 46 UNKNOWN_FUNCTION,导致即便已移除 client_protocol_version
的兼容重试路径仍然连接失败。
扩展现有 HTTP 兼容脚手架:新增 displayName Code 46 检测,复用同一条
兼容重试分支;兼容模式下的 RoundTripper 改写握手探测请求体,将
displayName() 替换为各版本通用的 hostName(),其余请求体原样放行。
Refs #479
|
2026-06-22 00:19:49 -07:00 |
|
Syngnat
|
4999fd544d
|
🐛 fix(data-sync): 完善多种目标库的 schema 同步链路
- 扩展数据同步目标端 schema 选择与元数据加载,覆盖 SQL Server、IRIS、DuckDB 等独立 schema 场景
- 修正同步链路中的目标表 schema 归一化与 query/apply 表名解析,避免落到错误模式
- 补充前后端回归测试与多语言文案,覆盖 schema 选择、别名识别和结果预览路径
Fixes #571
|
2026-06-21 22:46:57 +08:00 |
|
Syngnat
|
36233ba9aa
|
Merge pull request #580 from feat/573-redis-db-alias
feat(redis): per-database aliases in the sidebar
|
2026-06-21 16:42:36 +08:00 |
|
Matt Van Horn
|
4408bce159
|
feat(redis): support per-database alias in the Redis viewer tree
|
2026-06-21 00:44:22 -07:00 |
|
Syngnat
|
e7b8e78f9c
|
🐛 fix(query-editor): 修复当前语句快捷选择在 CRLF 文本下错位
- 统一当前语句选择与执行路径的归一化 offset/position 换算
- 避免 Windows CRLF 文本下 SQL 语句选区错位
- 补充 QueryEditor 当前语句选择回归测试
Fixes #575
|
2026-06-21 15:08:34 +08:00 |
|
Syngnat
|
29e7e365f1
|
📝 docs(readme): 补充 Trino 联邦查询支持说明
- 在中英文 README 的支持数据源列表中补充 Trino\n- 明确 Trino 作为跨多数据源联邦查询入口\n\nFixes #577
|
2026-06-21 14:11:36 +08:00 |
|
Syngnat
|
8ea7ecc477
|
✨ feat(trino): 新增 Trino 可选驱动接入并补齐查询支持
- 后端新增 Trino 数据库实现与 optional driver-agent provider
- 前端补齐 catalog.schema 连接配置、URI 解析与能力开关
- SQL 编辑器对 Trino 禁用托管事务并补充前后端测试
|
2026-06-21 13:54:42 +08:00 |
|
Syngnat
|
99b75378c3
|
✨ feat(data-grid): 完善 ER 图多层关系展开与字段浏览
- 支持按层扩展关联关系并重置为一层视图
- 支持节点字段展开收起与全部字段切换
- 补充 ER 图模型、Hook 与界面回归测试
|
2026-06-21 11:37:45 +08:00 |
|
Syngnat
|
5f56859898
|
🐛 fix(query-editor): 兜底 SQL 编辑器中文输入首次不上屏
- 补充 Monaco IME 组合输入提交兜底
- 统一拦截候选键避免快捷键链路抢占
- 增加 QueryEditor 中文输入回归测试
Fixes #578
|
2026-06-21 11:30:17 +08:00 |
|
Syngnat
|
7f2445a6f5
|
🐛 fix(monaco-editor): 禁用 EditContext 修复中文输入异常
- 在 MonacoEditor 中统一关闭 editContext
- 修复单引号场景下中文输入首次上屏异常
- 补充编辑器选项回归断言
Close #578
|
2026-06-20 17:05:38 +08:00 |
|
Syngnat
|
b3a54b3ff8
|
✨ feat(data-grid): 新增完整 ER 图视图并收口导出回归
- 新增完整 ER 图建模、布局与交互 hook
- 在元数据视图接入 ER 图并补齐样式与多语言文案
- 修正查询结果导出测试交互与 Wails 导出 mock
|
2026-06-20 15:45:58 +08:00 |
|
Syngnat
|
c8c8497a2f
|
✨ feat(query-editor): 收敛 SQL 分析工作台与结果区日志体验
- 新增 SQL 分析工作台,统一承载慢 SQL 和 SQL 诊断视图
- 将 SQL 执行日志收进结果区首个日志标签并在失败时展示错误摘要
- 调整侧边栏入口、标签展示、多语言文案与定向前端测试覆盖
|
2026-06-20 14:09:58 +08:00 |
|
Syngnat
|
04019135a0
|
🐛 fix(sql-diagnose): 兼容新版 MySQL JSON EXPLAIN 解析
- 兼容 query_plan 包装和新版 JSON V2 执行计划结构
- 补齐 covering index、table scan 等节点类型与统计归一化
- 增加新版 MySQL EXPLAIN 解析测试并修正 TotalCost 汇总逻辑
|
2026-06-20 14:08:02 +08:00 |
|
Syngnat
|
e7935db84b
|
✨ feat(db-connection): 新增连接后台定时探活保活能力
- 为连接配置新增 keepAlive 开关与探活间隔
- 在后端缓存连接上增加后台定时 Ping 调度与失效剔除
- 补充前端表单、Wails 模型映射与定向测试覆盖
Close #579
|
2026-06-20 11:24:44 +08:00 |
|
Syngnat
|
0f67305100
|
♻️ refactor(codebase): 拆分大文件并收敛模块职责
- 拆分 ConnectionModal、DataGrid、QueryEditor、App 等前端大文件
- 抽出 driver assets、v2 workbench 样式和 source-as-test 读取辅助
- 更新相关测试以覆盖拆分后的源码位置
|
2026-06-19 23:10:00 +08:00 |
|
Syngnat
|
6179c3fbd9
|
♻️ refactor(sidebar): 拆分动作与搜索逻辑
|
2026-06-19 18:46:08 +08:00 |
|
Syngnat
|
13705f9098
|
♻️ refactor(sidebar): 抽出 V2 右键菜单逻辑
|
2026-06-19 18:08:54 +08:00 |
|
Syngnat
|
1dea343aa2
|
♻️ refactor(sidebar): 抽出 V2 树标题渲染
|
2026-06-19 18:03:28 +08:00 |
|
Syngnat
|
293a8ff3e9
|
♻️ refactor(sidebar): 抽出实体操作弹窗
|
2026-06-19 17:56:12 +08:00 |
|
Syngnat
|
6e422aea33
|
♻️ refactor(sidebar): 抽出树节点加载器
|
2026-06-19 17:32:45 +08:00 |
|
Syngnat
|
39e52469f2
|
♻️ refactor(sidebar): 抽出批量操作弹窗
|
2026-06-19 17:23:53 +08:00 |
|
Syngnat
|
3ff5141184
|
♻️ refactor(sidebar): 抽出外部 SQL 文件流程
|
2026-06-19 17:13:24 +08:00 |
|
Syngnat
|
db31513c0b
|
♻️ refactor(sidebar): 抽出批量导出状态逻辑
|
2026-06-19 16:55:43 +08:00 |
|
Syngnat
|
5da2c7ff1a
|
♻️ refactor(sidebar): 抽出元数据加载工具
|
2026-06-19 16:45:15 +08:00 |
|
Syngnat
|
d109f2891f
|
♻️ refactor(sidebar): 复用 V2 侧栏工具函数
|
2026-06-19 16:33:16 +08:00 |
|
Syngnat
|
f946951580
|
♻️ refactor(sidebar): 迁出 legacy 节点菜单构建逻辑
|
2026-06-19 16:21:36 +08:00 |
|
Syngnat
|
f6ebfc2e44
|
♻️ refactor(sidebar): 清理 V2 rail 残留死代码
- 删除未被调用的 rail connection button/group 渲染闭包
- 移除对应的折叠、拖拽状态和 badge/host 辅助函数
- 保留当前可达的 active connection 状态展示和树拖拽排序逻辑
|
2026-06-19 15:16:31 +08:00 |
|
Syngnat
|
540dbc2a28
|
♻️ refactor(sidebar): 抽出 Command Search 面板组件
- 新建 SidebarSearchPanel,承接 V2 命令搜索弹层的行、分组和空状态渲染
- Sidebar.tsx 保留搜索状态、过滤和执行逻辑,仅通过 typed props 传入子组件
- 保持 @ 对象搜索、? AI 提问、同步过滤与键盘导航行为不变
|
2026-06-19 14:55:21 +08:00 |
|
Syngnat
|
2c8128724e
|
♻️ refactor(sidebar): 抽出 ConnectionRail 为独立子组件
- 新建 sidebar/SidebarConnectionRail.tsx:V2 连接栏(新建分组/批量导出/SQL 文件/定位/AI/工具/设置 7 个按钮)
- Props 用聚合对象(labels + handlers + canLocateActiveTab)避免 18+ 个独立 props drilling
- Sidebar.tsx 删除 renderV2ConnectionRail(-93 行),加 v2ConnectionRailProps 构造 + <SidebarConnectionRail /> 调用
- Sidebar.tsx 从 10187 减至 10122 行
|
2026-06-19 14:29:57 +08:00 |
|
Syngnat
|
528f3c51a0
|
♻️ refactor(sidebar): 迁出命令搜索相关类型与 shouldLoadSidebarNodeOnExpand
- 迁出 V2CommandSearchMode/V2CommandSearchQuery 类型与 parseV2CommandSearchQuery(支持 @/?前缀切换 object/ai 模式)
- 迁出 shouldLoadSidebarNodeOnExpand(节点懒加载判定)
- SidebarNodeLike 加可选 key 字段以适配测试用法
- Sidebar.tsx 从 10235 减至 10187 行,sidebarHelpers.ts 增至 215 行
|
2026-06-19 14:19:06 +08:00 |
|
Syngnat
|
a4d94624cd
|
♻️ refactor(sidebar): 继续抽离 resolveV2ObjectGroupTitle 等 2 个工具函数
- 新增 SidebarNodeLike 结构化类型,替代 Pick<TreeNode, ...> 解除对 Sidebar 内部类型的依赖
- 迁出 resolveV2ObjectGroupTitle(对象分组标题本地化)与 resolveSidebarTableNameForCopy(节点表名提取)
- Sidebar.tsx 从 10243 减至 10235 行
|
2026-06-19 14:15:35 +08:00 |
|
Syngnat
|
87bd16c4ba
|
♻️ refactor(sidebar): 抽离独立工具函数到 sidebarHelpers 模块
- 新建 sidebar/sidebarHelpers.ts:迁出 6 个无内部类型依赖的纯函数(formatSidebarRowCount/hasSidebarLazyChildren/getV2RailConnectionGroupBadgeText 等)+ V2ExplorerFilter 类型 + V2_RAIL_UNGROUPED 常量
- Sidebar.tsx 通过 import + re-export 双向引用,外部测试文件的 `from './Sidebar'` 保持兼容
- 文件规模:Sidebar.tsx 从 10275 减至 10243 行,建立 sidebar/ 子目录作为后续拆分的目标归宿
|
2026-06-19 14:11:54 +08:00 |
|
Syngnat
|
dc54d24d2b
|
✨ feat(sidebar): 新增 Sidebar 慢 SQL 历史浮动入口
- 新建 SlowQueryRailButton:独立小组件,从 store 直接读 tabs/connections 解析激活连接
- 挂载方式:浮动在 Sidebar 右下角,不修改 Sidebar.tsx 内部代码(避免改 10275 行的大文件)
- 体验优化:无激活连接时按钮自动禁用并 tooltip 提示;与 Ctrl+Shift+L 快捷键路径并存
- bundle 保持:SlowQueryPanel 继续走 lazy 加载独立 chunk,不进入主 bundle
|
2026-06-19 13:56:15 +08:00 |
|
Syngnat
|
8457f6c4b7
|
✨ feat(shortcuts): 把 SQL 诊断与慢查询快捷键注册到管理系统并加菜单入口
- 注册到系统:diagnoseQuery 与 showSlowQueries 加入 ShortcutAction,可在快捷键管理面板自定义
- 修复冲突:原硬编码 Ctrl+Shift+D 与 toggleTheme 冲突、Ctrl+Shift+H 与 toggleLogPanel 冲突;改为 Ctrl+Shift+P / Ctrl+Shift+L
- 菜单入口:QueryEditor 的"更多"下拉加 SQL 诊断、慢 SQL 历史两个菜单项,附带快捷键提示
- i18n 同步:6 种语言补齐 label/description
|
2026-06-19 13:43:12 +08:00 |
|