mirror of
https://github.com/Syngnat/GoNavi.git
synced 2026-05-12 07:19:39 +08:00
- 新增 DuckDB 与 Diros 后端驱动实现并接入数据库工厂 - 前端连接配置补充 DuckDB/Diros 入口及方言映射 - 侧边栏支持 DuckDB Macro 函数列表加载与对象分组展示 - 定义查看器支持 DuckDB 函数定义查询与 DDL 还原 - 后端补充 DuckDB 函数删除分支并限制存储过程操作
113 lines
2.4 KiB
Go
113 lines
2.4 KiB
Go
package sync
|
|
|
|
import "strings"
|
|
|
|
func normalizeSyncMode(mode string) string {
|
|
m := strings.ToLower(strings.TrimSpace(mode))
|
|
switch m {
|
|
case "", "insert_update":
|
|
return "insert_update"
|
|
case "insert_only":
|
|
return "insert_only"
|
|
case "full_overwrite":
|
|
return "full_overwrite"
|
|
default:
|
|
return "insert_update"
|
|
}
|
|
}
|
|
|
|
func quoteIdentByType(dbType string, ident string) string {
|
|
if ident == "" {
|
|
return ident
|
|
}
|
|
|
|
switch dbType {
|
|
case "mysql", "mariadb", "diros", "sphinx":
|
|
return "`" + strings.ReplaceAll(ident, "`", "``") + "`"
|
|
case "sqlserver":
|
|
escaped := strings.ReplaceAll(ident, "]", "]]")
|
|
return "[" + escaped + "]"
|
|
default:
|
|
return `"` + strings.ReplaceAll(ident, `"`, `""`) + `"`
|
|
}
|
|
}
|
|
|
|
func quoteQualifiedIdentByType(dbType string, ident string) string {
|
|
raw := strings.TrimSpace(ident)
|
|
if raw == "" {
|
|
return raw
|
|
}
|
|
|
|
parts := strings.Split(raw, ".")
|
|
if len(parts) <= 1 {
|
|
return quoteIdentByType(dbType, raw)
|
|
}
|
|
|
|
quotedParts := make([]string, 0, len(parts))
|
|
for _, part := range parts {
|
|
part = strings.TrimSpace(part)
|
|
if part == "" {
|
|
continue
|
|
}
|
|
quotedParts = append(quotedParts, quoteIdentByType(dbType, part))
|
|
}
|
|
|
|
if len(quotedParts) == 0 {
|
|
return quoteIdentByType(dbType, raw)
|
|
}
|
|
return strings.Join(quotedParts, ".")
|
|
}
|
|
|
|
func normalizeSchemaAndTable(dbType string, dbName string, tableName string) (string, string) {
|
|
rawTable := strings.TrimSpace(tableName)
|
|
rawDB := strings.TrimSpace(dbName)
|
|
if rawTable == "" {
|
|
return rawDB, rawTable
|
|
}
|
|
|
|
if parts := strings.SplitN(rawTable, ".", 2); len(parts) == 2 {
|
|
schema := strings.TrimSpace(parts[0])
|
|
table := strings.TrimSpace(parts[1])
|
|
if schema != "" && table != "" {
|
|
return schema, table
|
|
}
|
|
}
|
|
|
|
switch strings.ToLower(strings.TrimSpace(dbType)) {
|
|
case "postgres", "kingbase", "vastbase":
|
|
return "public", rawTable
|
|
default:
|
|
return rawDB, rawTable
|
|
}
|
|
}
|
|
|
|
func qualifiedNameForQuery(dbType string, schema string, table string, original string) string {
|
|
raw := strings.TrimSpace(original)
|
|
if raw == "" {
|
|
return raw
|
|
}
|
|
if strings.Contains(raw, ".") {
|
|
return raw
|
|
}
|
|
|
|
switch strings.ToLower(strings.TrimSpace(dbType)) {
|
|
case "postgres", "kingbase", "vastbase":
|
|
s := strings.TrimSpace(schema)
|
|
if s == "" {
|
|
s = "public"
|
|
}
|
|
if table == "" {
|
|
return raw
|
|
}
|
|
return s + "." + table
|
|
case "mysql", "mariadb", "diros", "sphinx":
|
|
s := strings.TrimSpace(schema)
|
|
if s == "" || table == "" {
|
|
return table
|
|
}
|
|
return s + "." + table
|
|
default:
|
|
return table
|
|
}
|
|
}
|