fdb2 1.0.17 → 1.0.19

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 (98) hide show
  1. package/dist/package.json +139 -0
  2. package/dist/pnpm-lock.yaml +7332 -0
  3. package/dist/public/.vite/manifest.json +102 -0
  4. package/dist/public/bootstrap-icons.woff +0 -0
  5. package/dist/public/bootstrap-icons.woff2 +0 -0
  6. package/dist/public/bootstrap.css +14152 -0
  7. package/dist/public/bootstrap.js +4717 -0
  8. package/dist/public/explorer.css +2542 -0
  9. package/dist/public/explorer.js +59311 -0
  10. package/dist/public/favicon.ico +0 -0
  11. package/dist/public/index.css +1099 -0
  12. package/dist/public/index.js +5533 -0
  13. package/dist/public/layout.css +318 -0
  14. package/dist/public/layout.js +35 -0
  15. package/dist/public/rolldown-runtime.js +38 -0
  16. package/dist/public/vconsole.min.js +10355 -0
  17. package/dist/public/vue.js +6542 -0
  18. package/dist/scripts/nw-build.js +136 -0
  19. package/dist/scripts/nw-dev.js +67 -0
  20. package/dist/scripts/preinstall.js +112 -0
  21. package/dist/server/index.d.ts +2 -0
  22. package/dist/server/index.d.ts.map +1 -0
  23. package/dist/server/index.js +607 -0
  24. package/dist/server/index.js.map +1 -0
  25. package/dist/server/index.ts +685 -0
  26. package/dist/server/model/connection.entity.d.ts +55 -0
  27. package/dist/server/model/connection.entity.d.ts.map +1 -0
  28. package/dist/server/model/connection.entity.js +59 -0
  29. package/dist/server/model/connection.entity.js.map +1 -0
  30. package/dist/server/model/connection.entity.ts +66 -0
  31. package/dist/server/model/database.entity.d.ts +203 -0
  32. package/dist/server/model/database.entity.d.ts.map +1 -0
  33. package/dist/server/model/database.entity.js +211 -0
  34. package/dist/server/model/database.entity.js.map +1 -0
  35. package/dist/server/model/database.entity.ts +246 -0
  36. package/dist/server/service/connection.service.d.ts +84 -0
  37. package/dist/server/service/connection.service.d.ts.map +1 -0
  38. package/dist/server/service/connection.service.js +369 -0
  39. package/dist/server/service/connection.service.js.map +1 -0
  40. package/dist/server/service/connection.service.ts +359 -0
  41. package/dist/server/service/database/base.service.d.ts +183 -0
  42. package/dist/server/service/database/base.service.d.ts.map +1 -0
  43. package/dist/server/service/database/base.service.js +253 -0
  44. package/dist/server/service/database/base.service.js.map +1 -0
  45. package/dist/server/service/database/base.service.ts +407 -0
  46. package/dist/server/service/database/cockroachdb.service.d.ts +116 -0
  47. package/dist/server/service/database/cockroachdb.service.d.ts.map +1 -0
  48. package/dist/server/service/database/cockroachdb.service.js +812 -0
  49. package/dist/server/service/database/cockroachdb.service.js.map +1 -0
  50. package/dist/server/service/database/cockroachdb.service.ts +871 -0
  51. package/dist/server/service/database/database.service.d.ts +495 -0
  52. package/dist/server/service/database/database.service.d.ts.map +1 -0
  53. package/dist/server/service/database/database.service.js +711 -0
  54. package/dist/server/service/database/database.service.js.map +1 -0
  55. package/dist/server/service/database/database.service.ts +776 -0
  56. package/dist/server/service/database/index.d.ts +8 -0
  57. package/dist/server/service/database/index.d.ts.map +1 -0
  58. package/dist/server/service/database/index.js +18 -0
  59. package/dist/server/service/database/index.js.map +1 -0
  60. package/dist/server/service/database/index.ts +7 -0
  61. package/dist/server/service/database/mongodb.service.d.ts +121 -0
  62. package/dist/server/service/database/mongodb.service.d.ts.map +1 -0
  63. package/dist/server/service/database/mongodb.service.js +502 -0
  64. package/dist/server/service/database/mongodb.service.js.map +1 -0
  65. package/dist/server/service/database/mongodb.service.ts +501 -0
  66. package/dist/server/service/database/mssql.service.d.ts +118 -0
  67. package/dist/server/service/database/mssql.service.d.ts.map +1 -0
  68. package/dist/server/service/database/mssql.service.js +871 -0
  69. package/dist/server/service/database/mssql.service.js.map +1 -0
  70. package/dist/server/service/database/mssql.service.ts +932 -0
  71. package/dist/server/service/database/mysql.service.d.ts +114 -0
  72. package/dist/server/service/database/mysql.service.d.ts.map +1 -0
  73. package/dist/server/service/database/mysql.service.js +960 -0
  74. package/dist/server/service/database/mysql.service.js.map +1 -0
  75. package/dist/server/service/database/mysql.service.ts +1026 -0
  76. package/dist/server/service/database/oracle.service.d.ts +126 -0
  77. package/dist/server/service/database/oracle.service.d.ts.map +1 -0
  78. package/dist/server/service/database/oracle.service.js +963 -0
  79. package/dist/server/service/database/oracle.service.js.map +1 -0
  80. package/dist/server/service/database/oracle.service.ts +1036 -0
  81. package/dist/server/service/database/postgres.service.d.ts +122 -0
  82. package/dist/server/service/database/postgres.service.d.ts.map +1 -0
  83. package/dist/server/service/database/postgres.service.js +882 -0
  84. package/dist/server/service/database/postgres.service.js.map +1 -0
  85. package/dist/server/service/database/postgres.service.ts +961 -0
  86. package/dist/server/service/database/sap.service.d.ts +115 -0
  87. package/dist/server/service/database/sap.service.d.ts.map +1 -0
  88. package/dist/server/service/database/sap.service.js +868 -0
  89. package/dist/server/service/database/sap.service.js.map +1 -0
  90. package/dist/server/service/database/sap.service.ts +922 -0
  91. package/dist/server/service/database/sqlite.service.d.ts +112 -0
  92. package/dist/server/service/database/sqlite.service.d.ts.map +1 -0
  93. package/dist/server/service/database/sqlite.service.js +723 -0
  94. package/dist/server/service/database/sqlite.service.js.map +1 -0
  95. package/dist/server/service/database/sqlite.service.ts +787 -0
  96. package/dist/server/service/session.service.ts +158 -0
  97. package/dist/view/index.html +45 -0
  98. package/package.json +9 -8
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection.service.js","sourceRoot":"","sources":["../../../server/service/connection.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,359 @@
1
+ import * as fs from 'fs';
2
+ import * as path from 'path';
3
+ import * as os from 'os';
4
+ import { ConnectionEntity } from '../model/connection.entity';
5
+ import { DataSource, type DataSourceOptions } from 'typeorm';
6
+
7
+ /**
8
+ * 数据库连接管理服务
9
+ * 负责管理数据库连接配置和连接实例
10
+ */
11
+ export class ConnectionService {
12
+
13
+ /**
14
+ * 连接配置文件路径
15
+ * 优先使用环境变量 DB_TOOL_DATA_DIR,否则使用用户主目录下的 .db-tool 目录
16
+ */
17
+ private readonly configPath: string;
18
+
19
+ /**
20
+ * 活跃的数据库连接实例
21
+ */
22
+ private activeConnections: Map<string, DataSource> = new Map();
23
+
24
+ constructor() {
25
+ const dataDir = process.env.DB_TOOL_DATA_DIR || path.join(os.homedir(), '.fdb2');
26
+ this.configPath = path.join(dataDir, 'connections.json');
27
+ }
28
+
29
+ /**
30
+ * 初始化服务,创建配置目录
31
+ */
32
+ async init() {
33
+ const configDir = path.dirname(this.configPath);
34
+ if (!fs.existsSync(configDir)) {
35
+ fs.mkdirSync(configDir, { recursive: true });
36
+ }
37
+ }
38
+
39
+ /**
40
+ * 获取所有数据库连接配置
41
+ */
42
+ async getAllConnections(): Promise<ConnectionEntity[]> {
43
+ try {
44
+ console.log('configPath', this.configPath);
45
+ if (!fs.existsSync(this.configPath)) {
46
+ return [];
47
+ }
48
+ const data = fs.readFileSync(this.configPath, 'utf8');
49
+ return JSON.parse(data) as ConnectionEntity[];
50
+ } catch (error) {
51
+ console.error('读取连接配置失败:', error);
52
+ return [];
53
+ }
54
+ }
55
+
56
+ /**
57
+ * 根据ID获取数据库连接配置
58
+ */
59
+ async getConnectionById(id: string): Promise<ConnectionEntity | null> {
60
+ const connections = await this.getAllConnections();
61
+ return connections.find(conn => conn.id === id) || null;
62
+ }
63
+
64
+ /**
65
+ * 添加数据库连接配置
66
+ */
67
+ async addConnection(connection: ConnectionEntity): Promise<ConnectionEntity> {
68
+ const connections = await this.getAllConnections();
69
+
70
+ // 检查名称是否重复
71
+ if (connections.find(conn => conn.name === connection.name)) {
72
+ throw new Error('连接名称已存在');
73
+ }
74
+
75
+ // 生成ID并设置时间戳
76
+ connection.id = this.generateId();
77
+ connection.createdAt = new Date();
78
+ connection.updatedAt = new Date();
79
+ connection.enabled = connection.enabled !== undefined ? connection.enabled : true;
80
+
81
+ connections.push(connection);
82
+ await this.saveConnections(connections);
83
+
84
+ return connection;
85
+ }
86
+
87
+ /**
88
+ * 更新数据库连接配置
89
+ */
90
+ async updateConnection(id: string, updates: Partial<ConnectionEntity>): Promise<ConnectionEntity> {
91
+ const connections = await this.getAllConnections();
92
+ const index = connections.findIndex(conn => conn.id === id);
93
+
94
+ if (index === -1) {
95
+ throw new Error('连接配置不存在');
96
+ }
97
+
98
+ // 检查名称重复
99
+ if (updates.name && connections.find((conn, idx) => conn.name === updates.name && idx !== index)) {
100
+ throw new Error('连接名称已存在');
101
+ }
102
+ // @ts-ignore
103
+ connections[index] = { ...connections[index], ...updates, updatedAt: new Date() };
104
+ await this.saveConnections(connections);
105
+ // @ts-ignore
106
+ return connections[index];
107
+ }
108
+
109
+ /**
110
+ * 删除数据库连接配置
111
+ */
112
+ async deleteConnection(id: string): Promise<void> {
113
+ const connections = await this.getAllConnections();
114
+ const filteredConnections = connections.filter(conn => conn.id !== id);
115
+
116
+ if (filteredConnections.length === connections.length) {
117
+ throw new Error('连接配置不存在');
118
+ }
119
+
120
+ // 关闭活跃连接
121
+ if (this.activeConnections.has(id)) {
122
+ await this.activeConnections.get(id)?.destroy();
123
+ this.activeConnections.delete(id);
124
+ }
125
+
126
+ await this.saveConnections(filteredConnections);
127
+ }
128
+
129
+ /**
130
+ * 测试数据库连接
131
+ */
132
+ async testConnection(connection: ConnectionEntity): Promise<boolean> {
133
+ try {
134
+ console.log('test', connection);
135
+ const tempDataSource = await this.createTypeORMDataSource(connection);
136
+ await tempDataSource.query('SELECT 1');
137
+ await tempDataSource.destroy();
138
+ return true;
139
+ } catch (error) {
140
+ console.error(error);
141
+ return false;
142
+ }
143
+ }
144
+
145
+ /**
146
+ * 获取活跃的数据库连接
147
+ */
148
+ async getActiveConnection(id: string, database?: string): Promise<DataSource> {
149
+ const key = database ? `${id}_${database}` : id;
150
+ if (this.activeConnections.has(key)) {
151
+ const db = this.activeConnections.get(key);
152
+ // 检查连接是否仍然有效
153
+ if (db?.isInitialized) {
154
+ return db;
155
+ } else {
156
+ // 连接已关闭,从缓存中移除
157
+ this.activeConnections.delete(key);
158
+ }
159
+ }
160
+
161
+ // 连接池大小限制,防止连接数无限增长
162
+ if (this.activeConnections.size >= 10) {
163
+ // 关闭最旧的连接
164
+ const oldestKey = this.activeConnections.keys().next().value || '';
165
+ const oldestConnection = this.activeConnections.get(oldestKey);
166
+ try {
167
+ await oldestConnection?.destroy();
168
+ } catch (error) {
169
+ console.error(`关闭旧连接 ${oldestKey} 失败:`, error);
170
+ }
171
+ this.activeConnections.delete(oldestKey);
172
+ }
173
+
174
+ const connectionConfig = await this.getConnectionById(id);
175
+ if (!connectionConfig) {
176
+ throw new Error('连接配置不存在');
177
+ }
178
+
179
+ // 创建一个新的连接配置,使用指定的数据库
180
+ const updatedConnectionConfig: ConnectionEntity = {
181
+ ...connectionConfig,
182
+ database: database || connectionConfig.database
183
+ };
184
+
185
+ const dataSource = await this.createTypeORMDataSource(updatedConnectionConfig);
186
+ this.activeConnections.set(key, dataSource);
187
+
188
+ return dataSource;
189
+ }
190
+
191
+ /**
192
+ * 关闭数据库连接
193
+ */
194
+ async closeConnection(id: string, database?: string): Promise<void> {
195
+ const key = database ? `${id}_${database}` : id;
196
+ if (this.activeConnections.has(key)) {
197
+ await this.activeConnections.get(key)?.destroy();
198
+ this.activeConnections.delete(key);
199
+ }
200
+ // 也关闭默认连接(如果存在)
201
+ if (database && this.activeConnections.has(id)) {
202
+ await this.activeConnections.get(id)?.destroy();
203
+ this.activeConnections.delete(id);
204
+ }
205
+ }
206
+
207
+ /**
208
+ * 关闭特定连接的所有数据库连接
209
+ */
210
+ async closeAllConnectionsForId(connectionId: string): Promise<void> {
211
+ const keysToDelete: string[] = [];
212
+ for (const [key, dataSource] of this.activeConnections) {
213
+ if (key.startsWith(connectionId + '_') || key === connectionId) {
214
+ try {
215
+ await dataSource.destroy();
216
+ keysToDelete.push(key);
217
+ } catch (error) {
218
+ console.error(`关闭连接 ${key} 失败:`, error);
219
+ }
220
+ }
221
+ }
222
+ keysToDelete.forEach(key => this.activeConnections.delete(key));
223
+ }
224
+
225
+ /**
226
+ * 关闭所有数据库连接
227
+ */
228
+ async closeAllConnections(): Promise<void> {
229
+ for (const [id, dataSource] of this.activeConnections) {
230
+ try {
231
+ await dataSource.destroy();
232
+ } catch (error) {
233
+ console.error(`关闭连接 ${id} 失败:`, error);
234
+ }
235
+ }
236
+ this.activeConnections.clear();
237
+ }
238
+
239
+ /**
240
+ * 创建TypeORM数据源
241
+ */
242
+ private async createTypeORMDataSource(connectionConfig: ConnectionEntity): Promise<DataSource> {
243
+ const connectionOptions = this.getTypeORMOptions(connectionConfig);
244
+ return new DataSource(connectionOptions).initialize();
245
+ }
246
+
247
+ /**
248
+ * 创建临时数据库连接
249
+ * 用于同步操作中的目标数据库连接
250
+ */
251
+ async createTemporaryConnection(connectionOptions: DataSourceOptions): Promise<DataSource> {
252
+ try {
253
+ const dataSource = new DataSource(connectionOptions);
254
+ await dataSource.initialize();
255
+ return dataSource;
256
+ } catch (error) {
257
+ console.error('创建临时连接失败:', error);
258
+ throw error;
259
+ }
260
+ }
261
+
262
+ /**
263
+ * 获取TypeORM连接配置
264
+ */
265
+ private getTypeORMOptions(connectionConfig: ConnectionEntity): DataSourceOptions {
266
+ const baseOptions = {
267
+ type: connectionConfig.type as any,
268
+ host: connectionConfig.host,
269
+ port: connectionConfig.port,
270
+ username: connectionConfig.username,
271
+ password: connectionConfig.password,
272
+ database: connectionConfig.database,
273
+ synchronize: false,
274
+ logging: false,
275
+ // 关键配置:开启多语句执行
276
+ extra: {
277
+ multipleStatements: true
278
+ },
279
+ ...connectionConfig.options
280
+ };
281
+
282
+ // 根据数据库类型调整配置
283
+ switch (connectionConfig.type.toLowerCase()) {
284
+ case 'sqlite':
285
+ case 'better-sqlite3':
286
+ case 'bettersqlite3':
287
+ return {
288
+ ...baseOptions,
289
+ type: 'better-sqlite3' as any,
290
+ database: connectionConfig.database,
291
+ host: undefined,
292
+ port: undefined,
293
+ username: undefined,
294
+ password: undefined
295
+ };
296
+ case 'postgres':
297
+ case 'postgresql':
298
+ return {
299
+ ...baseOptions,
300
+ type: 'postgres' as any,
301
+ ssl: connectionConfig.options?.ssl || false
302
+ };
303
+ case 'oracle':
304
+ return {
305
+ ...baseOptions,
306
+ type: 'oracle' as any,
307
+ connectString: `${connectionConfig.host}:${connectionConfig.port}/${connectionConfig.database}`,
308
+ host: undefined,
309
+ port: undefined,
310
+ database: undefined,
311
+ extra: {
312
+ connectionTimeout: 60000,
313
+ poolMax: 10,
314
+ poolMin: 1,
315
+ poolIncrement: 1
316
+ }
317
+ };
318
+ case 'mssql':
319
+ case 'sqlserver':
320
+ return {
321
+ ...baseOptions,
322
+ type: 'mssql' as any,
323
+ options: {
324
+ encrypt: connectionConfig.options?.encrypt || false,
325
+ trustServerCertificate: true
326
+ },
327
+ extra: {
328
+ connectionTimeout: 60000,
329
+ requestTimeout: 15000
330
+ }
331
+ };
332
+ default:
333
+ return baseOptions;
334
+ }
335
+ }
336
+
337
+ /**
338
+ * 保存连接配置到文件
339
+ */
340
+ private async saveConnections(connections: ConnectionEntity[]): Promise<void> {
341
+ try {
342
+ const dir = path.dirname(this.configPath);
343
+ if (!fs.existsSync(dir)) {
344
+ fs.mkdirSync(dir, { recursive: true });
345
+ }
346
+ fs.writeFileSync(this.configPath, JSON.stringify(connections, null, 2), 'utf8');
347
+ } catch (error) {
348
+ console.error('保存连接配置失败:', error);
349
+ throw error;
350
+ }
351
+ }
352
+
353
+ /**
354
+ * 生成唯一ID
355
+ */
356
+ private generateId(): string {
357
+ return Date.now().toString(36) + Math.random().toString(36).substr(2);
358
+ }
359
+ }
@@ -0,0 +1,183 @@
1
+ import { DataSource } from 'typeorm';
2
+ import { DatabaseEntity, TableEntity, ColumnEntity, IndexEntity, ForeignKeyEntity } from '../../model/database.entity';
3
+ /**
4
+ * 数据库服务基础类
5
+ * 提供所有数据库类型的通用操作
6
+ */
7
+ export declare abstract class BaseDatabaseService {
8
+ /**
9
+ * 获取数据库类型
10
+ */
11
+ abstract getDatabaseType(): string;
12
+ /**
13
+ * 获取数据库列表 - 子类实现
14
+ */
15
+ abstract getDatabases(dataSource: DataSource): Promise<string[]>;
16
+ /**
17
+ * 获取表列表 - 子类实现
18
+ */
19
+ abstract getTables(dataSource: DataSource, database: string): Promise<TableEntity[]>;
20
+ /**
21
+ * 获取列信息 - 子类实现
22
+ */
23
+ abstract getColumns(dataSource: DataSource, database: string, table: string): Promise<ColumnEntity[]>;
24
+ /**
25
+ * 获取索引信息 - 子类实现
26
+ */
27
+ abstract getIndexes(dataSource: DataSource, database: string, table: string): Promise<IndexEntity[]>;
28
+ /**
29
+ * 获取外键信息 - 子类实现
30
+ */
31
+ abstract getForeignKeys(dataSource: DataSource, database: string, table: string): Promise<ForeignKeyEntity[]>;
32
+ /**
33
+ * 获取数据库大小 - 子类实现
34
+ */
35
+ abstract getDatabaseSize(dataSource: DataSource, database: string): Promise<number>;
36
+ /**
37
+ * 通用方法:获取数据库详细信息
38
+ */
39
+ getDatabaseInfo(dataSource: DataSource, databaseName: string): Promise<DatabaseEntity>;
40
+ /**
41
+ * 通用方法:获取表详细信息
42
+ */
43
+ getTableInfo(dataSource: DataSource, databaseName: string, tableName: string): Promise<TableEntity>;
44
+ /**
45
+ * 获取表结构(包含列信息)
46
+ */
47
+ getTableStructure(dataSource: DataSource, databaseName: string, tableName: string): Promise<any>;
48
+ /**
49
+ * 通用方法:获取表数据
50
+ */
51
+ getTableData(dataSource: DataSource, databaseName: string, tableName: string, page?: number, pageSize?: number, where?: string, orderBy?: string): Promise<{
52
+ data: any[];
53
+ total: number;
54
+ }>;
55
+ /**
56
+ * 通用方法:执行SQL查询
57
+ */
58
+ executeQuery(dataSource: DataSource, sql: string): Promise<any>;
59
+ /**
60
+ * 批量执行SQL查询(支持多条语句)
61
+ */
62
+ executeBatchQuery(dataSource: DataSource, sqlStatements: string[], options?: {
63
+ batchSize?: number;
64
+ useTransaction?: boolean;
65
+ continueOnError?: boolean;
66
+ }): Promise<{
67
+ success: number;
68
+ failed: number;
69
+ errors: any[];
70
+ }>;
71
+ /**
72
+ * 执行文件中的SQL(支持大文件)
73
+ */
74
+ executeSqlFile(dataSource: DataSource, filePath: string, options?: {
75
+ batchSize?: number;
76
+ useTransaction?: boolean;
77
+ continueOnError?: boolean;
78
+ }): Promise<{
79
+ success: number;
80
+ failed: number;
81
+ errors: any[];
82
+ }>;
83
+ /**
84
+ * 通用方法:测试连接
85
+ */
86
+ testConnection(dataSource: DataSource): Promise<boolean>;
87
+ /**
88
+ * 通用方法:给标识符加引号
89
+ */
90
+ quoteIdentifier(identifier: string): string;
91
+ /**
92
+ * 通用方法:构建分页查询
93
+ */
94
+ protected buildPaginationQuery(baseQuery: string, page: number, pageSize: number): string;
95
+ /**
96
+ * 通用方法:构建计数查询
97
+ */
98
+ protected buildCountQuery(baseQuery: string): string;
99
+ /**
100
+ * 获取视图列表 - 子类实现(如果支持)
101
+ */
102
+ getViews(dataSource: DataSource, database: string): Promise<any[]>;
103
+ /**
104
+ * 获取视图定义 - 子类实现(如果支持)
105
+ */
106
+ getViewDefinition(dataSource: DataSource, database: string, viewName: string): Promise<string>;
107
+ /**
108
+ * 获取存储过程列表 - 子类实现(如果支持)
109
+ */
110
+ getProcedures(dataSource: DataSource, database: string): Promise<any[]>;
111
+ /**
112
+ * 获取存储过程定义 - 子类实现(如果支持)
113
+ */
114
+ getProcedureDefinition(dataSource: DataSource, database: string, procedureName: string): Promise<string>;
115
+ /**
116
+ * 导出数据库架构 - 子类实现
117
+ */
118
+ abstract exportSchema(dataSource: DataSource, database: string): Promise<string>;
119
+ /**
120
+ * 查看数据库日志 - 子类实现(如果支持)
121
+ */
122
+ abstract viewLogs(dataSource: DataSource, database?: string, limit?: number): Promise<any[]>;
123
+ /**
124
+ * 创建数据库 - 子类实现(如果支持)
125
+ */
126
+ createDatabase(dataSource: DataSource, databaseName: string, options?: any): Promise<void>;
127
+ /**
128
+ * 删除数据库 - 子类实现(如果支持)
129
+ */
130
+ dropDatabase(dataSource: DataSource, databaseName: string): Promise<void>;
131
+ /**
132
+ * 备份数据库 - 子类实现(如果支持)
133
+ */
134
+ backupDatabase(dataSource: DataSource, databaseName: string, options?: any): Promise<string>;
135
+ /**
136
+ * 恢复数据库 - 子类实现(如果支持)
137
+ */
138
+ restoreDatabase(dataSource: DataSource, databaseName: string, filePath: string, options?: any): Promise<void>;
139
+ /**
140
+ * 导出表数据到 SQL 文件 - 子类实现
141
+ */
142
+ abstract exportTableDataToSQL(dataSource: DataSource, databaseName: string, tableName: string, options?: any): Promise<string>;
143
+ /**
144
+ * 导出表数据到 CSV 文件 - 子类实现
145
+ */
146
+ abstract exportTableDataToCSV(dataSource: DataSource, databaseName: string, tableName: string, options?: any): Promise<string>;
147
+ /**
148
+ * 导出表数据到 JSON 文件 - 子类实现
149
+ */
150
+ abstract exportTableDataToJSON(dataSource: DataSource, databaseName: string, tableName: string, options?: any): Promise<string>;
151
+ /**
152
+ * 导出表数据到 Excel 文件 - 子类实现
153
+ */
154
+ abstract exportTableDataToExcel(dataSource: DataSource, databaseName: string, tableName: string, options?: any): Promise<string>;
155
+ /**
156
+ * 修改表结构 - 子类实现
157
+ */
158
+ abstract alterTable(dataSource: DataSource, databaseName: string, tableDiff: any): Promise<any>;
159
+ /**
160
+ * 批量插入数据 - 子类实现
161
+ */
162
+ abstract bulkInsert(dataSource: DataSource, databaseName: string, tableName: string, data: any[]): Promise<void>;
163
+ /**
164
+ * 插入单条数据 - 子类实现
165
+ */
166
+ abstract insertData(dataSource: DataSource, databaseName: string, tableName: string, data: any): Promise<void>;
167
+ /**
168
+ * 删除表 - 子类实现
169
+ */
170
+ abstract dropTable(dataSource: DataSource, databaseName: string, tableName: string): Promise<void>;
171
+ /**
172
+ * 创建表 - 子类实现
173
+ */
174
+ abstract createTable(dataSource: DataSource, databaseName: string, table: any): Promise<void>;
175
+ /**
176
+ * 执行查询 - 通用方法
177
+ */
178
+ query(dataSource: DataSource, queryOptions: {
179
+ sql: string;
180
+ params?: any[];
181
+ }): Promise<any[]>;
182
+ }
183
+ //# sourceMappingURL=base.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.service.d.ts","sourceRoot":"","sources":["../../../../server/service/database/base.service.ts"],"names":[],"mappings":"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"}