fdb2 1.0.13 → 1.0.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (313) hide show
  1. package/README.md +9 -2
  2. package/bin/docker/.env +4 -0
  3. package/package.json +26 -18
  4. package/public/favicon.ico +0 -0
  5. package/public/favicon.png +0 -0
  6. package/view/modules/header.tpl +1 -1
  7. package/.dockerignore +0 -21
  8. package/.editorconfig +0 -11
  9. package/.eslintrc.cjs +0 -14
  10. package/.eslintrc.json +0 -7
  11. package/.prettierrc.js +0 -3
  12. package/.tpl.env +0 -22
  13. package/.vscodeignore +0 -45
  14. package/dist/package.json +0 -115
  15. package/dist/pnpm-lock.yaml +0 -8135
  16. package/dist/public/.vite/manifest.json +0 -82
  17. package/dist/public/bootstrap-icons.woff +0 -0
  18. package/dist/public/bootstrap-icons.woff2 +0 -0
  19. package/dist/public/bootstrap.css +0 -14152
  20. package/dist/public/bootstrap.js +0 -5038
  21. package/dist/public/explorer.css +0 -2379
  22. package/dist/public/explorer.js +0 -50586
  23. package/dist/public/index.css +0 -1099
  24. package/dist/public/index.js +0 -12862
  25. package/dist/public/layout.css +0 -318
  26. package/dist/public/layout.js +0 -25
  27. package/dist/public/vue.css +0 -1
  28. package/dist/public/vue.js +0 -9110
  29. package/dist/scripts/preinstall.js +0 -112
  30. package/dist/server/index.d.ts +0 -2
  31. package/dist/server/index.d.ts.map +0 -1
  32. package/dist/server/index.js +0 -601
  33. package/dist/server/index.js.map +0 -1
  34. package/dist/server/index.ts +0 -681
  35. package/dist/server/model/connection.entity.d.ts +0 -55
  36. package/dist/server/model/connection.entity.d.ts.map +0 -1
  37. package/dist/server/model/connection.entity.js +0 -59
  38. package/dist/server/model/connection.entity.js.map +0 -1
  39. package/dist/server/model/connection.entity.ts +0 -66
  40. package/dist/server/model/database.entity.d.ts +0 -203
  41. package/dist/server/model/database.entity.d.ts.map +0 -1
  42. package/dist/server/model/database.entity.js +0 -211
  43. package/dist/server/model/database.entity.js.map +0 -1
  44. package/dist/server/model/database.entity.ts +0 -246
  45. package/dist/server/service/connection.service.d.ts +0 -84
  46. package/dist/server/service/connection.service.d.ts.map +0 -1
  47. package/dist/server/service/connection.service.js +0 -369
  48. package/dist/server/service/connection.service.js.map +0 -1
  49. package/dist/server/service/connection.service.ts +0 -359
  50. package/dist/server/service/database/base.service.d.ts +0 -183
  51. package/dist/server/service/database/base.service.d.ts.map +0 -1
  52. package/dist/server/service/database/base.service.js +0 -253
  53. package/dist/server/service/database/base.service.js.map +0 -1
  54. package/dist/server/service/database/base.service.ts +0 -407
  55. package/dist/server/service/database/cockroachdb.service.d.ts +0 -116
  56. package/dist/server/service/database/cockroachdb.service.d.ts.map +0 -1
  57. package/dist/server/service/database/cockroachdb.service.js +0 -812
  58. package/dist/server/service/database/cockroachdb.service.js.map +0 -1
  59. package/dist/server/service/database/cockroachdb.service.ts +0 -871
  60. package/dist/server/service/database/database.service.d.ts +0 -495
  61. package/dist/server/service/database/database.service.d.ts.map +0 -1
  62. package/dist/server/service/database/database.service.js +0 -711
  63. package/dist/server/service/database/database.service.js.map +0 -1
  64. package/dist/server/service/database/database.service.ts +0 -776
  65. package/dist/server/service/database/index.d.ts +0 -8
  66. package/dist/server/service/database/index.d.ts.map +0 -1
  67. package/dist/server/service/database/index.js +0 -18
  68. package/dist/server/service/database/index.js.map +0 -1
  69. package/dist/server/service/database/index.ts +0 -7
  70. package/dist/server/service/database/mongodb.service.d.ts +0 -121
  71. package/dist/server/service/database/mongodb.service.d.ts.map +0 -1
  72. package/dist/server/service/database/mongodb.service.js +0 -502
  73. package/dist/server/service/database/mongodb.service.js.map +0 -1
  74. package/dist/server/service/database/mongodb.service.ts +0 -501
  75. package/dist/server/service/database/mssql.service.d.ts +0 -118
  76. package/dist/server/service/database/mssql.service.d.ts.map +0 -1
  77. package/dist/server/service/database/mssql.service.js +0 -871
  78. package/dist/server/service/database/mssql.service.js.map +0 -1
  79. package/dist/server/service/database/mssql.service.ts +0 -932
  80. package/dist/server/service/database/mysql.service.d.ts +0 -114
  81. package/dist/server/service/database/mysql.service.d.ts.map +0 -1
  82. package/dist/server/service/database/mysql.service.js +0 -960
  83. package/dist/server/service/database/mysql.service.js.map +0 -1
  84. package/dist/server/service/database/mysql.service.ts +0 -1026
  85. package/dist/server/service/database/oracle.service.d.ts +0 -126
  86. package/dist/server/service/database/oracle.service.d.ts.map +0 -1
  87. package/dist/server/service/database/oracle.service.js +0 -963
  88. package/dist/server/service/database/oracle.service.js.map +0 -1
  89. package/dist/server/service/database/oracle.service.ts +0 -1036
  90. package/dist/server/service/database/postgres.service.d.ts +0 -122
  91. package/dist/server/service/database/postgres.service.d.ts.map +0 -1
  92. package/dist/server/service/database/postgres.service.js +0 -882
  93. package/dist/server/service/database/postgres.service.js.map +0 -1
  94. package/dist/server/service/database/postgres.service.ts +0 -961
  95. package/dist/server/service/database/sap.service.d.ts +0 -115
  96. package/dist/server/service/database/sap.service.d.ts.map +0 -1
  97. package/dist/server/service/database/sap.service.js +0 -868
  98. package/dist/server/service/database/sap.service.js.map +0 -1
  99. package/dist/server/service/database/sap.service.ts +0 -922
  100. package/dist/server/service/database/sqlite.service.d.ts +0 -112
  101. package/dist/server/service/database/sqlite.service.d.ts.map +0 -1
  102. package/dist/server/service/database/sqlite.service.js +0 -723
  103. package/dist/server/service/database/sqlite.service.js.map +0 -1
  104. package/dist/server/service/database/sqlite.service.ts +0 -787
  105. package/dist/server/service/session.service.ts +0 -158
  106. package/dist/view/index.html +0 -45
  107. package/env.d.ts +0 -1
  108. package/packages/vscode/.vscodeignore +0 -44
  109. package/packages/vscode/README.md +0 -62
  110. package/packages/vscode/out/database-services/base.service.js +0 -236
  111. package/packages/vscode/out/database-services/base.service.js.map +0 -1
  112. package/packages/vscode/out/database-services/cockroachdb.service.js +0 -634
  113. package/packages/vscode/out/database-services/cockroachdb.service.js.map +0 -1
  114. package/packages/vscode/out/database-services/connection.service.js +0 -346
  115. package/packages/vscode/out/database-services/connection.service.js.map +0 -1
  116. package/packages/vscode/out/database-services/database.service.js +0 -571
  117. package/packages/vscode/out/database-services/database.service.js.map +0 -1
  118. package/packages/vscode/out/database-services/index.js +0 -18
  119. package/packages/vscode/out/database-services/index.js.map +0 -1
  120. package/packages/vscode/out/database-services/model/connection.entity.js +0 -11
  121. package/packages/vscode/out/database-services/model/connection.entity.js.map +0 -1
  122. package/packages/vscode/out/database-services/model/database.entity.js +0 -35
  123. package/packages/vscode/out/database-services/model/database.entity.js.map +0 -1
  124. package/packages/vscode/out/database-services/mongodb.service.js +0 -458
  125. package/packages/vscode/out/database-services/mongodb.service.js.map +0 -1
  126. package/packages/vscode/out/database-services/mssql.service.js +0 -694
  127. package/packages/vscode/out/database-services/mssql.service.js.map +0 -1
  128. package/packages/vscode/out/database-services/mysql.service.js +0 -735
  129. package/packages/vscode/out/database-services/mysql.service.js.map +0 -1
  130. package/packages/vscode/out/database-services/oracle.service.js +0 -787
  131. package/packages/vscode/out/database-services/oracle.service.js.map +0 -1
  132. package/packages/vscode/out/database-services/postgres.service.js +0 -696
  133. package/packages/vscode/out/database-services/postgres.service.js.map +0 -1
  134. package/packages/vscode/out/database-services/sap.service.js +0 -695
  135. package/packages/vscode/out/database-services/sap.service.js.map +0 -1
  136. package/packages/vscode/out/database-services/sqlite.service.js +0 -532
  137. package/packages/vscode/out/database-services/sqlite.service.js.map +0 -1
  138. package/packages/vscode/out/extension.js +0 -93
  139. package/packages/vscode/out/extension.js.map +0 -1
  140. package/packages/vscode/out/provider/DatabaseTreeProvider.js +0 -159
  141. package/packages/vscode/out/provider/DatabaseTreeProvider.js.map +0 -1
  142. package/packages/vscode/out/provider/WebViewProvider.js +0 -259
  143. package/packages/vscode/out/provider/WebViewProvider.js.map +0 -1
  144. package/packages/vscode/out/service/ConnectionManager.js +0 -105
  145. package/packages/vscode/out/service/ConnectionManager.js.map +0 -1
  146. package/packages/vscode/out/service/DatabaseServiceBridge.js +0 -395
  147. package/packages/vscode/out/service/DatabaseServiceBridge.js.map +0 -1
  148. package/packages/vscode/out/typings/connection.js +0 -3
  149. package/packages/vscode/out/typings/connection.js.map +0 -1
  150. package/packages/vscode/package.json +0 -144
  151. package/packages/vscode/resources/icon.svg +0 -5
  152. package/packages/vscode/resources/webview/_plugin-vue_export-helper.js +0 -6529
  153. package/packages/vscode/resources/webview/_plugin-vue_export-helper.js.map +0 -1
  154. package/packages/vscode/resources/webview/connection.css +0 -69
  155. package/packages/vscode/resources/webview/connection.js +0 -228
  156. package/packages/vscode/resources/webview/connection.js.map +0 -1
  157. package/packages/vscode/resources/webview/database.css +0 -259
  158. package/packages/vscode/resources/webview/database.js +0 -275
  159. package/packages/vscode/resources/webview/database.js.map +0 -1
  160. package/packages/vscode/resources/webview/favicon.ico +0 -0
  161. package/packages/vscode/resources/webview/index.html +0 -9
  162. package/packages/vscode/resources/webview/modules/header.tpl +0 -14
  163. package/packages/vscode/resources/webview/modules/initial_state.tpl +0 -55
  164. package/packages/vscode/resources/webview/query.css +0 -162
  165. package/packages/vscode/resources/webview/query.js +0 -198
  166. package/packages/vscode/resources/webview/query.js.map +0 -1
  167. package/packages/vscode/src/database-services/base.service.js.map +0 -1
  168. package/packages/vscode/src/database-services/base.service.ts +0 -363
  169. package/packages/vscode/src/database-services/cockroachdb.service.js.map +0 -1
  170. package/packages/vscode/src/database-services/cockroachdb.service.ts +0 -659
  171. package/packages/vscode/src/database-services/connection.service.ts +0 -341
  172. package/packages/vscode/src/database-services/database.service.ts +0 -630
  173. package/packages/vscode/src/database-services/index.ts +0 -7
  174. package/packages/vscode/src/database-services/model/connection.entity.js +0 -11
  175. package/packages/vscode/src/database-services/model/connection.entity.js.map +0 -1
  176. package/packages/vscode/src/database-services/model/connection.entity.ts +0 -66
  177. package/packages/vscode/src/database-services/model/database.entity.js +0 -35
  178. package/packages/vscode/src/database-services/model/database.entity.js.map +0 -1
  179. package/packages/vscode/src/database-services/model/database.entity.ts +0 -246
  180. package/packages/vscode/src/database-services/mongodb.service.js.map +0 -1
  181. package/packages/vscode/src/database-services/mongodb.service.ts +0 -454
  182. package/packages/vscode/src/database-services/mssql.service.js.map +0 -1
  183. package/packages/vscode/src/database-services/mssql.service.ts +0 -723
  184. package/packages/vscode/src/database-services/mysql.service.js.map +0 -1
  185. package/packages/vscode/src/database-services/mysql.service.ts +0 -761
  186. package/packages/vscode/src/database-services/oracle.service.js.map +0 -1
  187. package/packages/vscode/src/database-services/oracle.service.ts +0 -832
  188. package/packages/vscode/src/database-services/postgres.service.js.map +0 -1
  189. package/packages/vscode/src/database-services/postgres.service.ts +0 -741
  190. package/packages/vscode/src/database-services/sap.service.js.map +0 -1
  191. package/packages/vscode/src/database-services/sap.service.ts +0 -713
  192. package/packages/vscode/src/database-services/sqlite.service.js.map +0 -1
  193. package/packages/vscode/src/database-services/sqlite.service.ts +0 -558
  194. package/packages/vscode/src/extension.ts +0 -76
  195. package/packages/vscode/src/provider/DatabaseTreeProvider.ts +0 -167
  196. package/packages/vscode/src/provider/WebViewProvider.ts +0 -277
  197. package/packages/vscode/src/service/DatabaseServiceBridge.ts +0 -414
  198. package/packages/vscode/src/typings/connection.ts +0 -90
  199. package/packages/vscode/tsconfig.json +0 -21
  200. package/scripts/preinstall.js +0 -112
  201. package/server/index.ts +0 -681
  202. package/server/model/connection.entity.js +0 -11
  203. package/server/model/connection.entity.js.map +0 -1
  204. package/server/model/connection.entity.ts +0 -66
  205. package/server/model/database.entity.js +0 -35
  206. package/server/model/database.entity.js.map +0 -1
  207. package/server/model/database.entity.ts +0 -246
  208. package/server/service/connection.service.ts +0 -359
  209. package/server/service/database/base.service.ts +0 -407
  210. package/server/service/database/cockroachdb.service.ts +0 -871
  211. package/server/service/database/database.service.ts +0 -776
  212. package/server/service/database/index.ts +0 -7
  213. package/server/service/database/mongodb.service.ts +0 -501
  214. package/server/service/database/mssql.service.ts +0 -932
  215. package/server/service/database/mysql.service.ts +0 -1026
  216. package/server/service/database/oracle.service.ts +0 -1036
  217. package/server/service/database/postgres.service.ts +0 -961
  218. package/server/service/database/sap.service.ts +0 -922
  219. package/server/service/database/sqlite.service.ts +0 -787
  220. package/server/service/session.service.ts +0 -158
  221. package/server/tsconfig.json +0 -20
  222. package/src/adapter/ajax.ts +0 -135
  223. package/src/assets/base.css +0 -1
  224. package/src/assets/database.css +0 -950
  225. package/src/assets/images/collapse.png +0 -0
  226. package/src/assets/images/no-login.png +0 -0
  227. package/src/assets/images/svg/illustrations/illustration-1.svg +0 -1
  228. package/src/assets/images/svg/illustrations/illustration-2.svg +0 -2
  229. package/src/assets/images/svg/illustrations/illustration-3.svg +0 -50
  230. package/src/assets/images/svg/illustrations/illustration-4.svg +0 -1
  231. package/src/assets/images/svg/illustrations/illustration-5.svg +0 -73
  232. package/src/assets/images/svg/illustrations/illustration-6.svg +0 -89
  233. package/src/assets/images/svg/illustrations/illustration-7.svg +0 -39
  234. package/src/assets/images/svg/illustrations/illustration-8.svg +0 -1
  235. package/src/assets/images/svg/separators/curve-2.svg +0 -3
  236. package/src/assets/images/svg/separators/curve.svg +0 -3
  237. package/src/assets/images/svg/separators/line.svg +0 -3
  238. package/src/assets/images/theme/light/screen-1-1000x800.jpg +0 -0
  239. package/src/assets/images/theme/light/screen-2-1000x800.jpg +0 -0
  240. package/src/assets/login/bg.jpg +0 -0
  241. package/src/assets/login/bg.png +0 -0
  242. package/src/assets/login/left.jpg +0 -0
  243. package/src/assets/logo.svg +0 -73
  244. package/src/assets/logo.webp +0 -0
  245. package/src/assets/main.css +0 -1
  246. package/src/base/config.ts +0 -20
  247. package/src/base/detect.ts +0 -134
  248. package/src/base/entity.ts +0 -92
  249. package/src/base/eventBus.ts +0 -37
  250. package/src/components/connection-editor/index.vue +0 -589
  251. package/src/components/dataGrid/index.vue +0 -163
  252. package/src/components/dataGrid/pagination.vue +0 -106
  253. package/src/components/loading/index.vue +0 -43
  254. package/src/components/modal/index.ts +0 -181
  255. package/src/components/modal/index.vue +0 -560
  256. package/src/components/toast/index.ts +0 -44
  257. package/src/components/toast/toast.vue +0 -58
  258. package/src/components/user/name.vue +0 -104
  259. package/src/components/user/selector.vue +0 -416
  260. package/src/domain/SysConfig.ts +0 -74
  261. package/src/platform/App.vue +0 -8
  262. package/src/platform/database/components/connection-detail.vue +0 -1153
  263. package/src/platform/database/components/data-editor.vue +0 -478
  264. package/src/platform/database/components/data-import-export.vue +0 -1602
  265. package/src/platform/database/components/database-detail.vue +0 -1199
  266. package/src/platform/database/components/database-monitor.vue +0 -1086
  267. package/src/platform/database/components/db-tools.vue +0 -1265
  268. package/src/platform/database/components/query-history.vue +0 -1349
  269. package/src/platform/database/components/sql-executor.vue +0 -738
  270. package/src/platform/database/components/sql-query-editor.vue +0 -1046
  271. package/src/platform/database/components/table-data-grid.vue +0 -273
  272. package/src/platform/database/components/table-detail.vue +0 -1173
  273. package/src/platform/database/components/table-editor.vue +0 -917
  274. package/src/platform/database/explorer.vue +0 -1840
  275. package/src/platform/database/index.vue +0 -1193
  276. package/src/platform/database/layout.vue +0 -367
  277. package/src/platform/database/router.ts +0 -37
  278. package/src/platform/database/styles/common.scss +0 -602
  279. package/src/platform/database/types/common.ts +0 -445
  280. package/src/platform/database/utils/export.ts +0 -232
  281. package/src/platform/database/utils/helpers.ts +0 -437
  282. package/src/platform/index.ts +0 -33
  283. package/src/platform/router.ts +0 -41
  284. package/src/platform/vscode/bridge.ts +0 -121
  285. package/src/platform/vscode/components/ConnectionPanel.vue +0 -272
  286. package/src/platform/vscode/components/DatabasePanel.vue +0 -532
  287. package/src/platform/vscode/components/QueryPanel.vue +0 -371
  288. package/src/platform/vscode/entry/connection.ts +0 -13
  289. package/src/platform/vscode/entry/database.ts +0 -13
  290. package/src/platform/vscode/entry/query.ts +0 -13
  291. package/src/platform/vscode/index.ts +0 -5
  292. package/src/service/base.ts +0 -134
  293. package/src/service/database.ts +0 -506
  294. package/src/service/login.ts +0 -121
  295. package/src/shims-vue.d.ts +0 -7
  296. package/src/stores/connection.ts +0 -266
  297. package/src/stores/session.ts +0 -87
  298. package/src/typings/database-types.ts +0 -413
  299. package/src/typings/database.ts +0 -364
  300. package/src/typings/global.d.ts +0 -58
  301. package/src/typings/pinia.d.ts +0 -8
  302. package/src/utils/clipboard.ts +0 -30
  303. package/src/utils/database-types.ts +0 -243
  304. package/src/utils/modal.ts +0 -124
  305. package/src/utils/request.ts +0 -55
  306. package/src/utils/sleep.ts +0 -4
  307. package/src/utils/toast.ts +0 -73
  308. package/src/utils/util.ts +0 -171
  309. package/src/utils/xlsx.ts +0 -228
  310. package/tsconfig.json +0 -33
  311. package/tsconfig.server.json +0 -19
  312. package/vite.config.ts +0 -424
  313. package/vite.config.vscode.ts +0 -47
@@ -1,776 +0,0 @@
1
- import { ConnectionService } from '../connection.service';
2
- import { BaseDatabaseService } from './base.service';
3
- import {
4
- DatabaseEntity,
5
- TableEntity
6
- } from '../../model/database.entity';
7
- import { MySQLService } from './mysql.service';
8
- import { PostgreSQLService } from './postgres.service';
9
- import { SQLiteService } from './sqlite.service';
10
- import { OracleService } from './oracle.service';
11
- import { SQLServerService } from './mssql.service';
12
- import { CockroachDBService } from './cockroachdb.service';
13
- import { MongoDBService } from './mongodb.service';
14
- import { SAPHANADatabaseService } from './sap.service';
15
-
16
- /**
17
- * 数据库服务管理类
18
- * 负责根据数据库类型选择相应的服务实现
19
- */
20
- export class DatabaseService {
21
-
22
- public connectionService: ConnectionService;
23
- private mysqlService: MySQLService;
24
- private postgreSQLService: PostgreSQLService;
25
- private sqliteService: SQLiteService;
26
- private oracleService: OracleService;
27
- private sqlServerService: SQLServerService;
28
- private cockroachDBService: CockroachDBService;
29
- private mongoDBService: MongoDBService;
30
- private sapHANADatabaseService: SAPHANADatabaseService;
31
-
32
- constructor() {
33
- this.connectionService = new ConnectionService();
34
-
35
- this.mysqlService = new MySQLService();
36
- this.postgreSQLService = new PostgreSQLService();
37
- this.sqliteService = new SQLiteService();
38
- this.oracleService = new OracleService();
39
- this.sqlServerService = new SQLServerService();
40
- this.cockroachDBService = new CockroachDBService();
41
- this.mongoDBService = new MongoDBService();
42
- this.sapHANADatabaseService = new SAPHANADatabaseService();
43
- }
44
-
45
- /**
46
- * 获取数据库服务实例
47
- */
48
- public getDatabaseService(type: string): BaseDatabaseService {
49
-
50
- switch (type.toLowerCase()) {
51
- case 'mysql':
52
- case 'aurora-mysql':
53
- case 'auroramysql':
54
- return this.mysqlService;
55
- case 'postgres':
56
- case 'postgresql':
57
- case 'aurora-postgres':
58
- case 'aurorapostgres':
59
- case 'aurora-postgresql':
60
- return this.postgreSQLService;
61
- case 'sqlite':
62
- case 'better-sqlite3':
63
- case 'bettersqlite3':
64
- return this.sqliteService;
65
- case 'oracle':
66
- return this.oracleService;
67
- case 'mssql':
68
- case 'sqlserver':
69
- return this.sqlServerService;
70
- case 'cockroachdb':
71
- case 'cockroach':
72
- return this.cockroachDBService;
73
- case 'mongodb':
74
- case 'mongo':
75
- return this.mongoDBService;
76
- case 'sap':
77
- case 'sap-hana':
78
- case 'saphana':
79
- return this.sapHANADatabaseService;
80
- default:
81
- throw new Error(`不支持的数据库类型: ${type}`);
82
- }
83
- }
84
-
85
- /**
86
- * 获取数据库列表
87
- */
88
- async getDatabases(connectionId: string): Promise<string[]> {
89
- const dataSource = await this.connectionService.getActiveConnection(connectionId);
90
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
91
- return databaseService.getDatabases(dataSource);
92
- }
93
-
94
- /**
95
- * 获取数据库详细信息
96
- */
97
- async getDatabaseInfo(connectionId: string, databaseName: string): Promise<DatabaseEntity> {
98
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
99
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
100
- return databaseService.getDatabaseInfo(dataSource, databaseName);
101
- }
102
-
103
- /**
104
- * 获取数据库表列表
105
- */
106
- async getTables(connectionId: string, databaseName: string): Promise<TableEntity[]> {
107
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
108
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
109
- return databaseService.getTables(dataSource, databaseName);
110
- }
111
-
112
- /**
113
- * 获取表详细信息
114
- */
115
- async getTableInfo(connectionId: string, databaseName: string, tableName: string): Promise<TableEntity> {
116
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
117
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
118
- return databaseService.getTableInfo(dataSource, databaseName, tableName);
119
- }
120
-
121
- /**
122
- * 获取表数据
123
- */
124
- async getTableData(
125
- connectionId: string,
126
- databaseName: string,
127
- tableName: string,
128
- page: number = 1,
129
- pageSize: number = 100,
130
- where?: string,
131
- orderBy?: string
132
- ): Promise<{ data: any[], total: number }> {
133
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
134
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
135
- return databaseService.getTableData(dataSource, databaseName, tableName, page, pageSize, where, orderBy);
136
- }
137
-
138
- /**
139
- * 执行SQL查询
140
- */
141
- async executeQuery(connectionId: string, sql: string, databaseName?: string): Promise<any> {
142
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
143
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
144
- return databaseService.executeQuery(dataSource, sql);
145
- }
146
-
147
- /**
148
- * 修改表结构
149
- */
150
- async alterTable(connectionId: string, databaseName: string, tableDiff: any): Promise<any> {
151
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
152
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
153
- return databaseService.alterTable(dataSource, databaseName, tableDiff);
154
- }
155
-
156
- /**
157
- * 同步表结构和数据到其他数据库
158
- */
159
- async syncTable(connectionId: string, syncConfig: any): Promise<any> {
160
- try {
161
- const { source, target, options } = syncConfig;
162
-
163
- // 获取源数据库连接
164
- const sourceDataSource = await this.connectionService.getActiveConnection(connectionId, source.database);
165
- const sourceService = this.getDatabaseService(sourceDataSource.options.type as string);
166
-
167
- // 创建目标数据库连接
168
- let targetDataSource;
169
- let targetService;
170
- let targetDatabaseName;
171
-
172
- if (target.connectionId) {
173
- // 使用已配置的连接
174
- const dbName = target.database || source.database;
175
- targetDataSource = await this.connectionService.getActiveConnection(target.connectionId, dbName);
176
- targetService = this.getDatabaseService(targetDataSource.options.type as string);
177
- targetDatabaseName = dbName;
178
- } else {
179
- // 使用手动配置的连接
180
- targetDataSource = await this.connectionService.createTemporaryConnection({
181
- type: target.dbType,
182
- host: target.host,
183
- port: target.port,
184
- username: target.username,
185
- password: target.password,
186
- database: target.database
187
- });
188
- targetService = this.getDatabaseService(target.dbType);
189
- targetDatabaseName = target.database;
190
- }
191
-
192
- const syncResults = [];
193
-
194
- // 处理单个表
195
- const sourceTableName = source.tableName;
196
- const tableSyncResult = {
197
- tableName: sourceTableName,
198
- structureSynced: false,
199
- dataSynced: false,
200
- rowsSynced: 0,
201
- messages: []
202
- };
203
-
204
- try {
205
- // 获取源表结构
206
- const tableStructure = await sourceService.getTableStructure(sourceDataSource, source.database, sourceTableName);
207
- const columns = tableStructure.columns;
208
-
209
- // 同步表结构
210
- if (options.syncStructure) {
211
- console.log(`开始同步表结构: ${sourceTableName} -> ${target.tableName}`);
212
- tableSyncResult.messages.push(`开始同步表结构: ${sourceTableName} -> ${target.tableName}`);
213
-
214
- // 检查目标表是否存在
215
- const targetTables = await targetService.getTables(targetDataSource, targetDatabaseName);
216
- const tableExists = targetTables.some(t => t.name === target.tableName);
217
-
218
- if (tableExists) {
219
- if (options.dropIfExists) {
220
- tableSyncResult.messages.push(`目标表已存在,删除表: ${target.tableName}`);
221
- await targetService.dropTable(targetDataSource, targetDatabaseName, target.tableName);
222
- } else {
223
- tableSyncResult.messages.push(`目标表已存在,跳过表结构同步`);
224
- }
225
- }
226
-
227
- if (!tableExists || options.dropIfExists) {
228
- tableSyncResult.messages.push(`创建目标表: ${target.tableName}`);
229
- await targetService.createTable(targetDataSource, targetDatabaseName, {
230
- name: target.tableName,
231
- columns: columns,
232
- comment: tableStructure.comment
233
- });
234
- tableSyncResult.structureSynced = true;
235
- }
236
- }
237
-
238
- // 同步表数据
239
- if (options.syncData) {
240
- tableSyncResult.messages.push(`开始同步表数据: ${sourceTableName} -> ${target.tableName}`);
241
-
242
- // 获取源表数据(分批获取,避免内存问题)
243
- const batchSize = 1000;
244
- let offset = 0;
245
- let totalRows = 0;
246
-
247
- while (true) {
248
- const sourceData = await sourceService.query(sourceDataSource, {
249
- sql: `SELECT * FROM ${sourceService.quoteIdentifier(sourceTableName)} LIMIT ? OFFSET ?`,
250
- params: [batchSize, offset]
251
- });
252
-
253
- if (sourceData.length === 0) {
254
- break;
255
- }
256
-
257
- // 插入数据到目标表
258
- if (options.bulkInsert) {
259
- await targetService.bulkInsert(targetDataSource, targetDatabaseName, target.tableName, sourceData, options.overrideExisting);
260
- } else {
261
- for (const row of sourceData) {
262
- await targetService.insertData(targetDataSource, targetDatabaseName, target.tableName, row, options.overrideExisting);
263
- }
264
- }
265
-
266
- totalRows += sourceData.length;
267
- tableSyncResult.messages.push(`已同步 ${totalRows} 行数据`);
268
- offset += batchSize;
269
- }
270
-
271
- tableSyncResult.dataSynced = true;
272
- tableSyncResult.rowsSynced = totalRows;
273
- tableSyncResult.messages.push(`数据同步完成,共同步 ${totalRows} 行`);
274
- }
275
-
276
- syncResults.push(tableSyncResult);
277
- } catch (error: any) {
278
- console.error(`同步表 ${sourceTableName} 失败:`, error);
279
- tableSyncResult.messages.push(`同步失败: ${error instanceof Error ? error.message : String(error)}`);
280
- syncResults.push(tableSyncResult);
281
- throw error;
282
- }
283
- finally {
284
- console.log(tableSyncResult.messages);
285
- }
286
- return { tables: syncResults };
287
- } catch (error: any) {
288
- console.error('同步表失败:', error);
289
- throw error;
290
- }
291
- }
292
-
293
- /**
294
- * 获取视图列表
295
- */
296
- async getViews(connectionId: string, databaseName: string): Promise<any[]> {
297
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
298
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
299
- return databaseService.getViews(dataSource, databaseName);
300
- }
301
-
302
- /**
303
- * 获取视图定义
304
- */
305
- async getViewDefinition(connectionId: string, databaseName: string, viewName: string): Promise<string> {
306
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
307
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
308
- return databaseService.getViewDefinition(dataSource, databaseName, viewName);
309
- }
310
-
311
- /**
312
- * 获取存储过程列表
313
- */
314
- async getProcedures(connectionId: string, databaseName: string): Promise<any[]> {
315
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
316
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
317
- return databaseService.getProcedures(dataSource, databaseName);
318
- }
319
-
320
- /**
321
- * 获取存储过程定义
322
- */
323
- async getProcedureDefinition(connectionId: string, databaseName: string, procedureName: string): Promise<string> {
324
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
325
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
326
- return databaseService.getProcedureDefinition(dataSource, databaseName, procedureName);
327
- }
328
-
329
- /**
330
- * 测试数据库连接
331
- */
332
- async testConnection(connectionId: string): Promise<boolean> {
333
- const dataSource = await this.connectionService.getActiveConnection(connectionId);
334
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
335
- return databaseService.testConnection(dataSource);
336
- }
337
-
338
- /**
339
- * 获取支持的数据库类型
340
- */
341
- getSupportedDatabaseTypes() {
342
- return [
343
- {
344
- value: 'mysql',
345
- label: 'MySQL',
346
- icon: 'bi-database',
347
- defaultPort: 3306,
348
- description: 'MySQL数据库',
349
- features: {
350
- supportSchemas: false,
351
- supportProcedures: true,
352
- supportTriggers: true,
353
- supportViews: true,
354
- supportFullTextSearch: true,
355
- supportJson: true
356
- }
357
- },
358
- {
359
- value: 'postgres',
360
- label: 'PostgreSQL',
361
- icon: 'bi-database',
362
- defaultPort: 5432,
363
- description: 'PostgreSQL数据库',
364
- features: {
365
- supportSchemas: true,
366
- supportProcedures: true,
367
- supportTriggers: true,
368
- supportViews: true,
369
- supportFullTextSearch: true,
370
- supportJson: true,
371
- supportArrays: true,
372
- supportEnum: true
373
- }
374
- },
375
- {
376
- value: 'sqlite',
377
- label: 'SQLite',
378
- icon: 'bi-database',
379
- defaultPort: null,
380
- description: 'SQLite数据库文件',
381
- features: {
382
- supportSchemas: false,
383
- supportProcedures: false,
384
- supportTriggers: true,
385
- supportViews: true,
386
- supportFullTextSearch: true,
387
- supportJson: false,
388
- supportArrays: false
389
- }
390
- },
391
- {
392
- value: 'oracle',
393
- label: 'Oracle',
394
- icon: 'bi-database',
395
- defaultPort: 1521,
396
- description: 'Oracle数据库',
397
- features: {
398
- supportSchemas: true,
399
- supportProcedures: true,
400
- supportTriggers: true,
401
- supportViews: true,
402
- supportFullTextSearch: true,
403
- supportJson: false,
404
- supportArrays: false,
405
- supportSequences: true,
406
- supportSynonyms: true
407
- }
408
- },
409
- {
410
- value: 'mssql',
411
- label: 'SQL Server',
412
- icon: 'bi-database',
413
- defaultPort: 1433,
414
- description: 'Microsoft SQL Server',
415
- features: {
416
- supportSchemas: false,
417
- supportProcedures: true,
418
- supportTriggers: true,
419
- supportViews: true,
420
- supportFullTextSearch: true,
421
- supportJson: true,
422
- supportArrays: false,
423
- supportStoredProcedures: true
424
- }
425
- },
426
- {
427
- value: 'cockroachdb',
428
- label: 'CockroachDB',
429
- icon: 'bi-database',
430
- defaultPort: 26257,
431
- description: 'CockroachDB分布式SQL数据库',
432
- features: {
433
- supportSchemas: true,
434
- supportProcedures: true,
435
- supportTriggers: true,
436
- supportViews: true,
437
- supportFullTextSearch: true,
438
- supportJson: true,
439
- supportArrays: true,
440
- supportEnum: true,
441
- supportDistributed: true
442
- }
443
- },
444
- {
445
- value: 'mongodb',
446
- label: 'MongoDB',
447
- icon: 'bi-database',
448
- defaultPort: 27017,
449
- description: 'MongoDB文档数据库',
450
- features: {
451
- supportSchemas: false,
452
- supportProcedures: false,
453
- supportTriggers: false,
454
- supportViews: false,
455
- supportFullTextSearch: true,
456
- supportJson: true,
457
- supportArrays: true,
458
- supportDocuments: true,
459
- supportNoSQL: true
460
- }
461
- },
462
- {
463
- value: 'sap',
464
- label: 'SAP HANA',
465
- icon: 'bi-database',
466
- defaultPort: 39013,
467
- description: 'SAP HANA内存数据库',
468
- features: {
469
- supportSchemas: true,
470
- supportProcedures: true,
471
- supportTriggers: true,
472
- supportViews: true,
473
- supportFullTextSearch: true,
474
- supportJson: true,
475
- supportArrays: false,
476
- supportInMemory: true,
477
- supportHighPerformance: true
478
- }
479
- }
480
- ];
481
- }
482
-
483
- /**
484
- * 创建数据库
485
- */
486
- async createDatabase(connectionId: string, databaseName: string, options?: any): Promise<void> {
487
- const dataSource = await this.connectionService.getActiveConnection(connectionId);
488
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
489
- return databaseService.createDatabase(dataSource, databaseName, options);
490
- }
491
-
492
- /**
493
- * 删除数据库
494
- */
495
- async dropDatabase(connectionId: string, databaseName: string): Promise<void> {
496
- const dataSource = await this.connectionService.getActiveConnection(connectionId);
497
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
498
- return databaseService.dropDatabase(dataSource, databaseName);
499
- }
500
-
501
- /**
502
- * 导出数据库架构
503
- */
504
- async exportSchema(connectionId: string, databaseName: string): Promise<string> {
505
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
506
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
507
- return databaseService.exportSchema(dataSource, databaseName);
508
- }
509
-
510
- /**
511
- * 查看数据库日志
512
- */
513
- async viewLogs(connectionId: string, databaseName?: string, limit: number = 100): Promise<any[]> {
514
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
515
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
516
- return databaseService.viewLogs(dataSource, databaseName, limit);
517
- }
518
-
519
- /**
520
- * 备份数据库
521
- */
522
- async backupDatabase(connectionId: string, databaseName: string, options?: any): Promise<string> {
523
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
524
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
525
- return databaseService.backupDatabase(dataSource, databaseName, options);
526
- }
527
-
528
- /**
529
- * 恢复数据库
530
- */
531
- async restoreDatabase(connectionId: string, databaseName: string, filePath: string, options?: any): Promise<void> {
532
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
533
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
534
- return databaseService.restoreDatabase(dataSource, databaseName, filePath, options);
535
- }
536
-
537
- /**
538
- * 获取数据库统计信息
539
- */
540
- async getDatabaseStats(connectionId: string, databaseName: string): Promise<any> {
541
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
542
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
543
-
544
- const tables = await databaseService.getTables(dataSource, databaseName);
545
- const tableCount = tables.length;
546
- const size = await databaseService.getDatabaseSize(dataSource, databaseName);
547
-
548
- return {
549
- tableCount,
550
- size,
551
- tables: tables.map(table => ({
552
- name: table.name,
553
- rowCount: table.rowCount || 0,
554
- size: table.dataSize || 0
555
- }))
556
- };
557
- }
558
-
559
- /**
560
- * 优化数据库
561
- */
562
- async optimizeDatabase(connectionId: string, databaseName: string): Promise<any> {
563
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
564
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
565
-
566
- const tables = await databaseService.getTables(dataSource, databaseName);
567
- const results = [];
568
-
569
- for (const table of tables) {
570
- try {
571
- const result = await dataSource.query(`OPTIMIZE TABLE \`${table.name}\``);
572
- results.push({ table: table.name, success: true, result });
573
- } catch (error) {
574
- results.push({ table: table.name, success: false, error: error.message });
575
- }
576
- }
577
-
578
- return { results };
579
- }
580
-
581
- /**
582
- * 分析表
583
- */
584
- async analyzeTables(connectionId: string, databaseName: string): Promise<any> {
585
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
586
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
587
-
588
- const tables = await databaseService.getTables(dataSource, databaseName);
589
- const results = [];
590
-
591
- for (const table of tables) {
592
- try {
593
- const result = await dataSource.query(`ANALYZE TABLE \`${table.name}\``);
594
- results.push({ table: table.name, success: true, result });
595
- } catch (error) {
596
- results.push({ table: table.name, success: false, error: error.message });
597
- }
598
- }
599
-
600
- return { results };
601
- }
602
-
603
- /**
604
- * 修复表
605
- */
606
- async repairTables(connectionId: string, databaseName: string): Promise<any> {
607
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
608
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
609
-
610
- const tables = await databaseService.getTables(dataSource, databaseName);
611
- const results = [];
612
-
613
- for (const table of tables) {
614
- try {
615
- const result = await dataSource.query(`REPAIR TABLE \`${table.name}\``);
616
- results.push({ table: table.name, success: true, result });
617
- } catch (error) {
618
- results.push({ table: table.name, success: false, error: error.message });
619
- }
620
- }
621
-
622
- return { results };
623
- }
624
-
625
- /**
626
- * 导出表数据到 SQL 文件
627
- */
628
- async exportTableDataToSQL(connectionId: string, databaseName: string, tableName: string, options?: any): Promise<string> {
629
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
630
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
631
- return databaseService.exportTableDataToSQL(dataSource, databaseName, tableName, options);
632
- }
633
-
634
- /**
635
- * 导出表数据到 CSV 文件
636
- */
637
- async exportTableDataToCSV(connectionId: string, databaseName: string, tableName: string, options?: any): Promise<string> {
638
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
639
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
640
- return databaseService.exportTableDataToCSV(dataSource, databaseName, tableName, options);
641
- }
642
-
643
- /**
644
- * 导出表数据到 JSON 文件
645
- */
646
- async exportTableDataToJSON(connectionId: string, databaseName: string, tableName: string, options?: any): Promise<string> {
647
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
648
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
649
- return databaseService.exportTableDataToJSON(dataSource, databaseName, tableName, options);
650
- }
651
-
652
- /**
653
- * 导出表数据到 Excel 文件
654
- */
655
- async exportTableDataToExcel(connectionId: string, databaseName: string, tableName: string, options?: any): Promise<string> {
656
- const dataSource = await this.connectionService.getActiveConnection(connectionId, databaseName);
657
- const databaseService = this.getDatabaseService(dataSource.options.type as string);
658
- return databaseService.exportTableDataToExcel(dataSource, databaseName, tableName, options);
659
- }
660
-
661
- /**
662
- * 获取数据库类型特定的配置
663
- */
664
- getDatabaseTypeSpecificConfig(type: string) {
665
- const service = this.getDatabaseService(type);
666
- return {
667
- type: service.getDatabaseType(),
668
- features: this.getDatabaseFeatures(type)
669
- };
670
- }
671
-
672
- /**
673
- * 获取数据库特性
674
- */
675
- private getDatabaseFeatures(type: string) {
676
- switch (type.toLowerCase()) {
677
- case 'mysql':
678
- return {
679
- supportSchemas: false,
680
- supportProcedures: true,
681
- supportTriggers: true,
682
- supportViews: true,
683
- supportFullTextSearch: true,
684
- supportJson: true
685
- };
686
- case 'postgres':
687
- case 'postgresql':
688
- return {
689
- supportSchemas: true,
690
- supportProcedures: true,
691
- supportTriggers: true,
692
- supportViews: true,
693
- supportFullTextSearch: true,
694
- supportJson: true,
695
- supportArrays: true,
696
- supportEnum: true
697
- };
698
- case 'sqlite':
699
- return {
700
- supportSchemas: false,
701
- supportProcedures: false,
702
- supportTriggers: true,
703
- supportViews: true,
704
- supportFullTextSearch: true,
705
- supportJson: false,
706
- supportArrays: false
707
- };
708
- case 'oracle':
709
- return {
710
- supportSchemas: true,
711
- supportProcedures: true,
712
- supportTriggers: true,
713
- supportViews: true,
714
- supportFullTextSearch: true,
715
- supportJson: false,
716
- supportArrays: false,
717
- supportSequences: true,
718
- supportSynonyms: true
719
- };
720
- case 'mssql':
721
- case 'sqlserver':
722
- return {
723
- supportSchemas: false,
724
- supportProcedures: true,
725
- supportTriggers: true,
726
- supportViews: true,
727
- supportFullTextSearch: true,
728
- supportJson: true,
729
- supportArrays: false,
730
- supportStoredProcedures: true
731
- };
732
- case 'cockroachdb':
733
- case 'cockroach':
734
- return {
735
- supportSchemas: true,
736
- supportProcedures: true,
737
- supportTriggers: true,
738
- supportViews: true,
739
- supportFullTextSearch: true,
740
- supportJson: true,
741
- supportArrays: true,
742
- supportEnum: true,
743
- supportDistributed: true
744
- };
745
- case 'mongodb':
746
- case 'mongo':
747
- return {
748
- supportSchemas: false,
749
- supportProcedures: false,
750
- supportTriggers: false,
751
- supportViews: false,
752
- supportFullTextSearch: true,
753
- supportJson: true,
754
- supportArrays: true,
755
- supportDocuments: true,
756
- supportNoSQL: true
757
- };
758
- case 'sap':
759
- case 'sap-hana':
760
- case 'saphana':
761
- return {
762
- supportSchemas: true,
763
- supportProcedures: true,
764
- supportTriggers: true,
765
- supportViews: true,
766
- supportFullTextSearch: true,
767
- supportJson: true,
768
- supportArrays: false,
769
- supportInMemory: true,
770
- supportHighPerformance: true
771
- };
772
- default:
773
- return {};
774
- }
775
- }
776
- }