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.
- package/README.md +9 -2
- package/bin/docker/.env +4 -0
- package/package.json +26 -18
- package/public/favicon.ico +0 -0
- package/public/favicon.png +0 -0
- package/view/modules/header.tpl +1 -1
- package/.dockerignore +0 -21
- package/.editorconfig +0 -11
- package/.eslintrc.cjs +0 -14
- package/.eslintrc.json +0 -7
- package/.prettierrc.js +0 -3
- package/.tpl.env +0 -22
- package/.vscodeignore +0 -45
- package/dist/package.json +0 -115
- package/dist/pnpm-lock.yaml +0 -8135
- package/dist/public/.vite/manifest.json +0 -82
- package/dist/public/bootstrap-icons.woff +0 -0
- package/dist/public/bootstrap-icons.woff2 +0 -0
- package/dist/public/bootstrap.css +0 -14152
- package/dist/public/bootstrap.js +0 -5038
- package/dist/public/explorer.css +0 -2379
- package/dist/public/explorer.js +0 -50586
- package/dist/public/index.css +0 -1099
- package/dist/public/index.js +0 -12862
- package/dist/public/layout.css +0 -318
- package/dist/public/layout.js +0 -25
- package/dist/public/vue.css +0 -1
- package/dist/public/vue.js +0 -9110
- package/dist/scripts/preinstall.js +0 -112
- package/dist/server/index.d.ts +0 -2
- package/dist/server/index.d.ts.map +0 -1
- package/dist/server/index.js +0 -601
- package/dist/server/index.js.map +0 -1
- package/dist/server/index.ts +0 -681
- package/dist/server/model/connection.entity.d.ts +0 -55
- package/dist/server/model/connection.entity.d.ts.map +0 -1
- package/dist/server/model/connection.entity.js +0 -59
- package/dist/server/model/connection.entity.js.map +0 -1
- package/dist/server/model/connection.entity.ts +0 -66
- package/dist/server/model/database.entity.d.ts +0 -203
- package/dist/server/model/database.entity.d.ts.map +0 -1
- package/dist/server/model/database.entity.js +0 -211
- package/dist/server/model/database.entity.js.map +0 -1
- package/dist/server/model/database.entity.ts +0 -246
- package/dist/server/service/connection.service.d.ts +0 -84
- package/dist/server/service/connection.service.d.ts.map +0 -1
- package/dist/server/service/connection.service.js +0 -369
- package/dist/server/service/connection.service.js.map +0 -1
- package/dist/server/service/connection.service.ts +0 -359
- package/dist/server/service/database/base.service.d.ts +0 -183
- package/dist/server/service/database/base.service.d.ts.map +0 -1
- package/dist/server/service/database/base.service.js +0 -253
- package/dist/server/service/database/base.service.js.map +0 -1
- package/dist/server/service/database/base.service.ts +0 -407
- package/dist/server/service/database/cockroachdb.service.d.ts +0 -116
- package/dist/server/service/database/cockroachdb.service.d.ts.map +0 -1
- package/dist/server/service/database/cockroachdb.service.js +0 -812
- package/dist/server/service/database/cockroachdb.service.js.map +0 -1
- package/dist/server/service/database/cockroachdb.service.ts +0 -871
- package/dist/server/service/database/database.service.d.ts +0 -495
- package/dist/server/service/database/database.service.d.ts.map +0 -1
- package/dist/server/service/database/database.service.js +0 -711
- package/dist/server/service/database/database.service.js.map +0 -1
- package/dist/server/service/database/database.service.ts +0 -776
- package/dist/server/service/database/index.d.ts +0 -8
- package/dist/server/service/database/index.d.ts.map +0 -1
- package/dist/server/service/database/index.js +0 -18
- package/dist/server/service/database/index.js.map +0 -1
- package/dist/server/service/database/index.ts +0 -7
- package/dist/server/service/database/mongodb.service.d.ts +0 -121
- package/dist/server/service/database/mongodb.service.d.ts.map +0 -1
- package/dist/server/service/database/mongodb.service.js +0 -502
- package/dist/server/service/database/mongodb.service.js.map +0 -1
- package/dist/server/service/database/mongodb.service.ts +0 -501
- package/dist/server/service/database/mssql.service.d.ts +0 -118
- package/dist/server/service/database/mssql.service.d.ts.map +0 -1
- package/dist/server/service/database/mssql.service.js +0 -871
- package/dist/server/service/database/mssql.service.js.map +0 -1
- package/dist/server/service/database/mssql.service.ts +0 -932
- package/dist/server/service/database/mysql.service.d.ts +0 -114
- package/dist/server/service/database/mysql.service.d.ts.map +0 -1
- package/dist/server/service/database/mysql.service.js +0 -960
- package/dist/server/service/database/mysql.service.js.map +0 -1
- package/dist/server/service/database/mysql.service.ts +0 -1026
- package/dist/server/service/database/oracle.service.d.ts +0 -126
- package/dist/server/service/database/oracle.service.d.ts.map +0 -1
- package/dist/server/service/database/oracle.service.js +0 -963
- package/dist/server/service/database/oracle.service.js.map +0 -1
- package/dist/server/service/database/oracle.service.ts +0 -1036
- package/dist/server/service/database/postgres.service.d.ts +0 -122
- package/dist/server/service/database/postgres.service.d.ts.map +0 -1
- package/dist/server/service/database/postgres.service.js +0 -882
- package/dist/server/service/database/postgres.service.js.map +0 -1
- package/dist/server/service/database/postgres.service.ts +0 -961
- package/dist/server/service/database/sap.service.d.ts +0 -115
- package/dist/server/service/database/sap.service.d.ts.map +0 -1
- package/dist/server/service/database/sap.service.js +0 -868
- package/dist/server/service/database/sap.service.js.map +0 -1
- package/dist/server/service/database/sap.service.ts +0 -922
- package/dist/server/service/database/sqlite.service.d.ts +0 -112
- package/dist/server/service/database/sqlite.service.d.ts.map +0 -1
- package/dist/server/service/database/sqlite.service.js +0 -723
- package/dist/server/service/database/sqlite.service.js.map +0 -1
- package/dist/server/service/database/sqlite.service.ts +0 -787
- package/dist/server/service/session.service.ts +0 -158
- package/dist/view/index.html +0 -45
- package/env.d.ts +0 -1
- package/packages/vscode/.vscodeignore +0 -44
- package/packages/vscode/README.md +0 -62
- package/packages/vscode/out/database-services/base.service.js +0 -236
- package/packages/vscode/out/database-services/base.service.js.map +0 -1
- package/packages/vscode/out/database-services/cockroachdb.service.js +0 -634
- package/packages/vscode/out/database-services/cockroachdb.service.js.map +0 -1
- package/packages/vscode/out/database-services/connection.service.js +0 -346
- package/packages/vscode/out/database-services/connection.service.js.map +0 -1
- package/packages/vscode/out/database-services/database.service.js +0 -571
- package/packages/vscode/out/database-services/database.service.js.map +0 -1
- package/packages/vscode/out/database-services/index.js +0 -18
- package/packages/vscode/out/database-services/index.js.map +0 -1
- package/packages/vscode/out/database-services/model/connection.entity.js +0 -11
- package/packages/vscode/out/database-services/model/connection.entity.js.map +0 -1
- package/packages/vscode/out/database-services/model/database.entity.js +0 -35
- package/packages/vscode/out/database-services/model/database.entity.js.map +0 -1
- package/packages/vscode/out/database-services/mongodb.service.js +0 -458
- package/packages/vscode/out/database-services/mongodb.service.js.map +0 -1
- package/packages/vscode/out/database-services/mssql.service.js +0 -694
- package/packages/vscode/out/database-services/mssql.service.js.map +0 -1
- package/packages/vscode/out/database-services/mysql.service.js +0 -735
- package/packages/vscode/out/database-services/mysql.service.js.map +0 -1
- package/packages/vscode/out/database-services/oracle.service.js +0 -787
- package/packages/vscode/out/database-services/oracle.service.js.map +0 -1
- package/packages/vscode/out/database-services/postgres.service.js +0 -696
- package/packages/vscode/out/database-services/postgres.service.js.map +0 -1
- package/packages/vscode/out/database-services/sap.service.js +0 -695
- package/packages/vscode/out/database-services/sap.service.js.map +0 -1
- package/packages/vscode/out/database-services/sqlite.service.js +0 -532
- package/packages/vscode/out/database-services/sqlite.service.js.map +0 -1
- package/packages/vscode/out/extension.js +0 -93
- package/packages/vscode/out/extension.js.map +0 -1
- package/packages/vscode/out/provider/DatabaseTreeProvider.js +0 -159
- package/packages/vscode/out/provider/DatabaseTreeProvider.js.map +0 -1
- package/packages/vscode/out/provider/WebViewProvider.js +0 -259
- package/packages/vscode/out/provider/WebViewProvider.js.map +0 -1
- package/packages/vscode/out/service/ConnectionManager.js +0 -105
- package/packages/vscode/out/service/ConnectionManager.js.map +0 -1
- package/packages/vscode/out/service/DatabaseServiceBridge.js +0 -395
- package/packages/vscode/out/service/DatabaseServiceBridge.js.map +0 -1
- package/packages/vscode/out/typings/connection.js +0 -3
- package/packages/vscode/out/typings/connection.js.map +0 -1
- package/packages/vscode/package.json +0 -144
- package/packages/vscode/resources/icon.svg +0 -5
- package/packages/vscode/resources/webview/_plugin-vue_export-helper.js +0 -6529
- package/packages/vscode/resources/webview/_plugin-vue_export-helper.js.map +0 -1
- package/packages/vscode/resources/webview/connection.css +0 -69
- package/packages/vscode/resources/webview/connection.js +0 -228
- package/packages/vscode/resources/webview/connection.js.map +0 -1
- package/packages/vscode/resources/webview/database.css +0 -259
- package/packages/vscode/resources/webview/database.js +0 -275
- package/packages/vscode/resources/webview/database.js.map +0 -1
- package/packages/vscode/resources/webview/favicon.ico +0 -0
- package/packages/vscode/resources/webview/index.html +0 -9
- package/packages/vscode/resources/webview/modules/header.tpl +0 -14
- package/packages/vscode/resources/webview/modules/initial_state.tpl +0 -55
- package/packages/vscode/resources/webview/query.css +0 -162
- package/packages/vscode/resources/webview/query.js +0 -198
- package/packages/vscode/resources/webview/query.js.map +0 -1
- package/packages/vscode/src/database-services/base.service.js.map +0 -1
- package/packages/vscode/src/database-services/base.service.ts +0 -363
- package/packages/vscode/src/database-services/cockroachdb.service.js.map +0 -1
- package/packages/vscode/src/database-services/cockroachdb.service.ts +0 -659
- package/packages/vscode/src/database-services/connection.service.ts +0 -341
- package/packages/vscode/src/database-services/database.service.ts +0 -630
- package/packages/vscode/src/database-services/index.ts +0 -7
- package/packages/vscode/src/database-services/model/connection.entity.js +0 -11
- package/packages/vscode/src/database-services/model/connection.entity.js.map +0 -1
- package/packages/vscode/src/database-services/model/connection.entity.ts +0 -66
- package/packages/vscode/src/database-services/model/database.entity.js +0 -35
- package/packages/vscode/src/database-services/model/database.entity.js.map +0 -1
- package/packages/vscode/src/database-services/model/database.entity.ts +0 -246
- package/packages/vscode/src/database-services/mongodb.service.js.map +0 -1
- package/packages/vscode/src/database-services/mongodb.service.ts +0 -454
- package/packages/vscode/src/database-services/mssql.service.js.map +0 -1
- package/packages/vscode/src/database-services/mssql.service.ts +0 -723
- package/packages/vscode/src/database-services/mysql.service.js.map +0 -1
- package/packages/vscode/src/database-services/mysql.service.ts +0 -761
- package/packages/vscode/src/database-services/oracle.service.js.map +0 -1
- package/packages/vscode/src/database-services/oracle.service.ts +0 -832
- package/packages/vscode/src/database-services/postgres.service.js.map +0 -1
- package/packages/vscode/src/database-services/postgres.service.ts +0 -741
- package/packages/vscode/src/database-services/sap.service.js.map +0 -1
- package/packages/vscode/src/database-services/sap.service.ts +0 -713
- package/packages/vscode/src/database-services/sqlite.service.js.map +0 -1
- package/packages/vscode/src/database-services/sqlite.service.ts +0 -558
- package/packages/vscode/src/extension.ts +0 -76
- package/packages/vscode/src/provider/DatabaseTreeProvider.ts +0 -167
- package/packages/vscode/src/provider/WebViewProvider.ts +0 -277
- package/packages/vscode/src/service/DatabaseServiceBridge.ts +0 -414
- package/packages/vscode/src/typings/connection.ts +0 -90
- package/packages/vscode/tsconfig.json +0 -21
- package/scripts/preinstall.js +0 -112
- package/server/index.ts +0 -681
- package/server/model/connection.entity.js +0 -11
- package/server/model/connection.entity.js.map +0 -1
- package/server/model/connection.entity.ts +0 -66
- package/server/model/database.entity.js +0 -35
- package/server/model/database.entity.js.map +0 -1
- package/server/model/database.entity.ts +0 -246
- package/server/service/connection.service.ts +0 -359
- package/server/service/database/base.service.ts +0 -407
- package/server/service/database/cockroachdb.service.ts +0 -871
- package/server/service/database/database.service.ts +0 -776
- package/server/service/database/index.ts +0 -7
- package/server/service/database/mongodb.service.ts +0 -501
- package/server/service/database/mssql.service.ts +0 -932
- package/server/service/database/mysql.service.ts +0 -1026
- package/server/service/database/oracle.service.ts +0 -1036
- package/server/service/database/postgres.service.ts +0 -961
- package/server/service/database/sap.service.ts +0 -922
- package/server/service/database/sqlite.service.ts +0 -787
- package/server/service/session.service.ts +0 -158
- package/server/tsconfig.json +0 -20
- package/src/adapter/ajax.ts +0 -135
- package/src/assets/base.css +0 -1
- package/src/assets/database.css +0 -950
- package/src/assets/images/collapse.png +0 -0
- package/src/assets/images/no-login.png +0 -0
- package/src/assets/images/svg/illustrations/illustration-1.svg +0 -1
- package/src/assets/images/svg/illustrations/illustration-2.svg +0 -2
- package/src/assets/images/svg/illustrations/illustration-3.svg +0 -50
- package/src/assets/images/svg/illustrations/illustration-4.svg +0 -1
- package/src/assets/images/svg/illustrations/illustration-5.svg +0 -73
- package/src/assets/images/svg/illustrations/illustration-6.svg +0 -89
- package/src/assets/images/svg/illustrations/illustration-7.svg +0 -39
- package/src/assets/images/svg/illustrations/illustration-8.svg +0 -1
- package/src/assets/images/svg/separators/curve-2.svg +0 -3
- package/src/assets/images/svg/separators/curve.svg +0 -3
- package/src/assets/images/svg/separators/line.svg +0 -3
- package/src/assets/images/theme/light/screen-1-1000x800.jpg +0 -0
- package/src/assets/images/theme/light/screen-2-1000x800.jpg +0 -0
- package/src/assets/login/bg.jpg +0 -0
- package/src/assets/login/bg.png +0 -0
- package/src/assets/login/left.jpg +0 -0
- package/src/assets/logo.svg +0 -73
- package/src/assets/logo.webp +0 -0
- package/src/assets/main.css +0 -1
- package/src/base/config.ts +0 -20
- package/src/base/detect.ts +0 -134
- package/src/base/entity.ts +0 -92
- package/src/base/eventBus.ts +0 -37
- package/src/components/connection-editor/index.vue +0 -589
- package/src/components/dataGrid/index.vue +0 -163
- package/src/components/dataGrid/pagination.vue +0 -106
- package/src/components/loading/index.vue +0 -43
- package/src/components/modal/index.ts +0 -181
- package/src/components/modal/index.vue +0 -560
- package/src/components/toast/index.ts +0 -44
- package/src/components/toast/toast.vue +0 -58
- package/src/components/user/name.vue +0 -104
- package/src/components/user/selector.vue +0 -416
- package/src/domain/SysConfig.ts +0 -74
- package/src/platform/App.vue +0 -8
- package/src/platform/database/components/connection-detail.vue +0 -1153
- package/src/platform/database/components/data-editor.vue +0 -478
- package/src/platform/database/components/data-import-export.vue +0 -1602
- package/src/platform/database/components/database-detail.vue +0 -1199
- package/src/platform/database/components/database-monitor.vue +0 -1086
- package/src/platform/database/components/db-tools.vue +0 -1265
- package/src/platform/database/components/query-history.vue +0 -1349
- package/src/platform/database/components/sql-executor.vue +0 -738
- package/src/platform/database/components/sql-query-editor.vue +0 -1046
- package/src/platform/database/components/table-data-grid.vue +0 -273
- package/src/platform/database/components/table-detail.vue +0 -1173
- package/src/platform/database/components/table-editor.vue +0 -917
- package/src/platform/database/explorer.vue +0 -1840
- package/src/platform/database/index.vue +0 -1193
- package/src/platform/database/layout.vue +0 -367
- package/src/platform/database/router.ts +0 -37
- package/src/platform/database/styles/common.scss +0 -602
- package/src/platform/database/types/common.ts +0 -445
- package/src/platform/database/utils/export.ts +0 -232
- package/src/platform/database/utils/helpers.ts +0 -437
- package/src/platform/index.ts +0 -33
- package/src/platform/router.ts +0 -41
- package/src/platform/vscode/bridge.ts +0 -121
- package/src/platform/vscode/components/ConnectionPanel.vue +0 -272
- package/src/platform/vscode/components/DatabasePanel.vue +0 -532
- package/src/platform/vscode/components/QueryPanel.vue +0 -371
- package/src/platform/vscode/entry/connection.ts +0 -13
- package/src/platform/vscode/entry/database.ts +0 -13
- package/src/platform/vscode/entry/query.ts +0 -13
- package/src/platform/vscode/index.ts +0 -5
- package/src/service/base.ts +0 -134
- package/src/service/database.ts +0 -506
- package/src/service/login.ts +0 -121
- package/src/shims-vue.d.ts +0 -7
- package/src/stores/connection.ts +0 -266
- package/src/stores/session.ts +0 -87
- package/src/typings/database-types.ts +0 -413
- package/src/typings/database.ts +0 -364
- package/src/typings/global.d.ts +0 -58
- package/src/typings/pinia.d.ts +0 -8
- package/src/utils/clipboard.ts +0 -30
- package/src/utils/database-types.ts +0 -243
- package/src/utils/modal.ts +0 -124
- package/src/utils/request.ts +0 -55
- package/src/utils/sleep.ts +0 -4
- package/src/utils/toast.ts +0 -73
- package/src/utils/util.ts +0 -171
- package/src/utils/xlsx.ts +0 -228
- package/tsconfig.json +0 -33
- package/tsconfig.server.json +0 -19
- package/vite.config.ts +0 -424
- package/vite.config.vscode.ts +0 -47
|
@@ -1,198 +0,0 @@
|
|
|
1
|
-
import { d as defineComponent, g as getVSCodeBridge, o as onMounted, a as openBlock, c as createElementBlock, b as createBaseVNode, w as withDirectives, e as vModelSelect, F as Fragment, r as renderList, v as vModelText, t as toDisplayString, i as ref, l as computed, _ as _export_sfc, k as createApp } from "./_plugin-vue_export-helper.js";
|
|
2
|
-
const _hoisted_1 = { class: "query-panel" };
|
|
3
|
-
const _hoisted_2 = { class: "query-toolbar" };
|
|
4
|
-
const _hoisted_3 = ["value"];
|
|
5
|
-
const _hoisted_4 = { class: "query-editor" };
|
|
6
|
-
const _hoisted_5 = { class: "query-results" };
|
|
7
|
-
const _hoisted_6 = {
|
|
8
|
-
key: 0,
|
|
9
|
-
class: "loading-state"
|
|
10
|
-
};
|
|
11
|
-
const _hoisted_7 = {
|
|
12
|
-
key: 1,
|
|
13
|
-
class: "results"
|
|
14
|
-
};
|
|
15
|
-
const _hoisted_8 = { class: "results-header" };
|
|
16
|
-
const _hoisted_9 = { class: "results-meta" };
|
|
17
|
-
const _hoisted_10 = { class: "data-table" };
|
|
18
|
-
const _hoisted_11 = {
|
|
19
|
-
key: 2,
|
|
20
|
-
class: "empty-state"
|
|
21
|
-
};
|
|
22
|
-
const _hoisted_12 = { class: "status-bar" };
|
|
23
|
-
const _hoisted_13 = { class: "status-item" };
|
|
24
|
-
const _hoisted_14 = { class: "status-item" };
|
|
25
|
-
const _hoisted_15 = { id: "statusTime" };
|
|
26
|
-
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
27
|
-
__name: "QueryPanel",
|
|
28
|
-
setup(__props) {
|
|
29
|
-
const vscode = getVSCodeBridge();
|
|
30
|
-
const connections = ref([]);
|
|
31
|
-
const selectedConnectionId = ref("");
|
|
32
|
-
const queryText = ref("");
|
|
33
|
-
const queryResults = ref(null);
|
|
34
|
-
const loading = ref(false);
|
|
35
|
-
const queryTextarea = ref(null);
|
|
36
|
-
const selectedConnection = computed(() => {
|
|
37
|
-
return connections.value.find((c) => c.id === selectedConnectionId.value);
|
|
38
|
-
});
|
|
39
|
-
onMounted(() => {
|
|
40
|
-
vscode.postMessage({ command: "getConnections" });
|
|
41
|
-
vscode.onMessage((message) => {
|
|
42
|
-
if (message.command === "connections") {
|
|
43
|
-
connections.value = message.data;
|
|
44
|
-
} else if (message.command === "queryResult") {
|
|
45
|
-
displayQueryResult(message.data);
|
|
46
|
-
} else if (message.command === "error") {
|
|
47
|
-
handleError(message.data);
|
|
48
|
-
}
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
function handleConnectionChange() {
|
|
52
|
-
}
|
|
53
|
-
function handleKeydown(e) {
|
|
54
|
-
if ((e.ctrlKey || e.metaKey) && e.key === "Enter") {
|
|
55
|
-
e.preventDefault();
|
|
56
|
-
executeQuery();
|
|
57
|
-
}
|
|
58
|
-
if (e.key === "Tab") {
|
|
59
|
-
e.preventDefault();
|
|
60
|
-
const textarea = queryTextarea.value;
|
|
61
|
-
if (textarea) {
|
|
62
|
-
const start = textarea.selectionStart;
|
|
63
|
-
const end = textarea.selectionEnd;
|
|
64
|
-
queryText.value = queryText.value.substring(0, start) + " " + queryText.value.substring(end);
|
|
65
|
-
textarea.selectionStart = textarea.selectionEnd = start + 2;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
function executeQuery() {
|
|
70
|
-
if (!selectedConnectionId.value) {
|
|
71
|
-
alert("请先选择数据库连接");
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
if (!queryText.value.trim()) {
|
|
75
|
-
alert("请输入 SQL 查询语句");
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
loading.value = true;
|
|
79
|
-
vscode.postMessage({
|
|
80
|
-
command: "executeQuery",
|
|
81
|
-
data: {
|
|
82
|
-
connectionId: selectedConnectionId.value,
|
|
83
|
-
sql: queryText.value
|
|
84
|
-
}
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
function clearQuery() {
|
|
88
|
-
queryText.value = "";
|
|
89
|
-
queryResults.value = null;
|
|
90
|
-
}
|
|
91
|
-
function displayQueryResult(data) {
|
|
92
|
-
queryResults.value = data;
|
|
93
|
-
loading.value = false;
|
|
94
|
-
}
|
|
95
|
-
function handleError(error) {
|
|
96
|
-
loading.value = false;
|
|
97
|
-
alert(`查询错误: ${error}`);
|
|
98
|
-
}
|
|
99
|
-
function formatCell(cell) {
|
|
100
|
-
if (cell === null || cell === void 0) {
|
|
101
|
-
return "NULL";
|
|
102
|
-
}
|
|
103
|
-
if (typeof cell === "boolean") {
|
|
104
|
-
return cell ? "✓" : "✗";
|
|
105
|
-
}
|
|
106
|
-
if (typeof cell === "object") {
|
|
107
|
-
return JSON.stringify(cell);
|
|
108
|
-
}
|
|
109
|
-
return String(cell);
|
|
110
|
-
}
|
|
111
|
-
return (_ctx, _cache) => {
|
|
112
|
-
return openBlock(), createElementBlock("div", _hoisted_1, [
|
|
113
|
-
createBaseVNode("div", _hoisted_2, [
|
|
114
|
-
withDirectives(createBaseVNode("select", {
|
|
115
|
-
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => selectedConnectionId.value = $event),
|
|
116
|
-
class: "query-selector",
|
|
117
|
-
onChange: handleConnectionChange
|
|
118
|
-
}, [
|
|
119
|
-
_cache[2] || (_cache[2] = createBaseVNode("option", { value: "" }, "选择数据库连接", -1)),
|
|
120
|
-
(openBlock(true), createElementBlock(Fragment, null, renderList(connections.value, (conn) => {
|
|
121
|
-
return openBlock(), createElementBlock("option", {
|
|
122
|
-
key: conn.id,
|
|
123
|
-
value: conn.id
|
|
124
|
-
}, toDisplayString(conn.name) + " (" + toDisplayString(conn.host) + ":" + toDisplayString(conn.port) + ") ", 9, _hoisted_3);
|
|
125
|
-
}), 128))
|
|
126
|
-
], 544), [
|
|
127
|
-
[vModelSelect, selectedConnectionId.value]
|
|
128
|
-
]),
|
|
129
|
-
createBaseVNode("button", {
|
|
130
|
-
onClick: executeQuery,
|
|
131
|
-
class: "btn btn-primary"
|
|
132
|
-
}, " 执行 (Ctrl+Enter) "),
|
|
133
|
-
createBaseVNode("button", {
|
|
134
|
-
onClick: clearQuery,
|
|
135
|
-
class: "btn btn-secondary"
|
|
136
|
-
}, " 清空 ")
|
|
137
|
-
]),
|
|
138
|
-
createBaseVNode("div", _hoisted_4, [
|
|
139
|
-
withDirectives(createBaseVNode("textarea", {
|
|
140
|
-
ref_key: "queryTextarea",
|
|
141
|
-
ref: queryTextarea,
|
|
142
|
-
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => queryText.value = $event),
|
|
143
|
-
class: "query-textarea",
|
|
144
|
-
placeholder: "在此输入 SQL 查询语句...\n\n例如: SELECT * FROM users LIMIT 100",
|
|
145
|
-
onKeydown: handleKeydown
|
|
146
|
-
}, null, 544), [
|
|
147
|
-
[vModelText, queryText.value]
|
|
148
|
-
])
|
|
149
|
-
]),
|
|
150
|
-
createBaseVNode("div", _hoisted_5, [
|
|
151
|
-
loading.value ? (openBlock(), createElementBlock("div", _hoisted_6, [..._cache[3] || (_cache[3] = [
|
|
152
|
-
createBaseVNode("div", { class: "spinner" }, null, -1),
|
|
153
|
-
createBaseVNode("span", null, "执行中...", -1)
|
|
154
|
-
])])) : queryResults.value ? (openBlock(), createElementBlock("div", _hoisted_7, [
|
|
155
|
-
createBaseVNode("div", _hoisted_8, [
|
|
156
|
-
_cache[4] || (_cache[4] = createBaseVNode("div", { class: "results-title" }, "查询结果", -1)),
|
|
157
|
-
createBaseVNode("div", _hoisted_9, toDisplayString(queryResults.value.rowCount) + " 行 · " + toDisplayString(queryResults.value.executionTime) + "ms ", 1)
|
|
158
|
-
]),
|
|
159
|
-
createBaseVNode("table", _hoisted_10, [
|
|
160
|
-
createBaseVNode("thead", null, [
|
|
161
|
-
createBaseVNode("tr", null, [
|
|
162
|
-
(openBlock(true), createElementBlock(Fragment, null, renderList(queryResults.value.columns, (col) => {
|
|
163
|
-
return openBlock(), createElementBlock("th", { key: col }, toDisplayString(col), 1);
|
|
164
|
-
}), 128))
|
|
165
|
-
])
|
|
166
|
-
]),
|
|
167
|
-
createBaseVNode("tbody", null, [
|
|
168
|
-
(openBlock(true), createElementBlock(Fragment, null, renderList(queryResults.value.rows, (row, index) => {
|
|
169
|
-
return openBlock(), createElementBlock("tr", { key: index }, [
|
|
170
|
-
(openBlock(true), createElementBlock(Fragment, null, renderList(row, (cell, cellIndex) => {
|
|
171
|
-
return openBlock(), createElementBlock("td", { key: cellIndex }, toDisplayString(formatCell(cell)), 1);
|
|
172
|
-
}), 128))
|
|
173
|
-
]);
|
|
174
|
-
}), 128))
|
|
175
|
-
])
|
|
176
|
-
])
|
|
177
|
-
])) : (openBlock(), createElementBlock("div", _hoisted_11, [..._cache[5] || (_cache[5] = [
|
|
178
|
-
createBaseVNode("div", { class: "empty-icon" }, "📊", -1),
|
|
179
|
-
createBaseVNode("div", { class: "empty-text" }, "执行查询后,结果将显示在这里", -1)
|
|
180
|
-
])]))
|
|
181
|
-
]),
|
|
182
|
-
createBaseVNode("div", _hoisted_12, [
|
|
183
|
-
createBaseVNode("div", _hoisted_13, [
|
|
184
|
-
_cache[6] || (_cache[6] = createBaseVNode("span", { class: "status-icon" }, "🔗", -1)),
|
|
185
|
-
createBaseVNode("span", null, toDisplayString(selectedConnection.value?.name || "未选择连接"), 1)
|
|
186
|
-
]),
|
|
187
|
-
createBaseVNode("div", _hoisted_14, [
|
|
188
|
-
createBaseVNode("span", _hoisted_15, toDisplayString(queryResults.value ? `执行时间: ${queryResults.value.executionTime}ms` : ""), 1)
|
|
189
|
-
])
|
|
190
|
-
])
|
|
191
|
-
]);
|
|
192
|
-
};
|
|
193
|
-
}
|
|
194
|
-
});
|
|
195
|
-
const QueryPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-eaf4025e"]]);
|
|
196
|
-
const app = createApp(QueryPanel);
|
|
197
|
-
app.mount("#app");
|
|
198
|
-
//# sourceMappingURL=query.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"query.js","sources":["../../../../src/platform/vscode/components/QueryPanel.vue","../../../../src/platform/vscode/entry/query.ts"],"sourcesContent":["<template>\r\n <div class=\"query-panel\">\r\n <div class=\"query-toolbar\">\r\n <select v-model=\"selectedConnectionId\" class=\"query-selector\" @change=\"handleConnectionChange\">\r\n <option value=\"\">选择数据库连接</option>\r\n <option v-for=\"conn in connections\" :key=\"conn.id\" :value=\"conn.id\">\r\n {{ conn.name }} ({{ conn.host }}:{{ conn.port }})\r\n </option>\r\n </select>\r\n <button @click=\"executeQuery\" class=\"btn btn-primary\">\r\n 执行 (Ctrl+Enter)\r\n </button>\r\n <button @click=\"clearQuery\" class=\"btn btn-secondary\">\r\n 清空\r\n </button>\r\n </div>\r\n\r\n <div class=\"query-editor\">\r\n <textarea\r\n ref=\"queryTextarea\"\r\n v-model=\"queryText\"\r\n class=\"query-textarea\"\r\n placeholder=\"在此输入 SQL 查询语句... 例如: SELECT * FROM users LIMIT 100\"\r\n @keydown=\"handleKeydown\"\r\n ></textarea>\r\n </div>\r\n\r\n <div class=\"query-results\">\r\n <div v-if=\"loading\" class=\"loading-state\">\r\n <div class=\"spinner\"></div>\r\n <span>执行中...</span>\r\n </div>\r\n <div v-else-if=\"queryResults\" class=\"results\">\r\n <div class=\"results-header\">\r\n <div class=\"results-title\">查询结果</div>\r\n <div class=\"results-meta\">\r\n {{ queryResults.rowCount }} 行 · {{ queryResults.executionTime }}ms\r\n </div>\r\n </div>\r\n\r\n <table class=\"data-table\">\r\n <thead>\r\n <tr>\r\n <th v-for=\"col in queryResults.columns\" :key=\"col\">{{ col }}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr v-for=\"(row, index) in queryResults.rows\" :key=\"index\">\r\n <td v-for=\"(cell, cellIndex) in row\" :key=\"cellIndex\">\r\n {{ formatCell(cell) }}\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n <div v-else class=\"empty-state\">\r\n <div class=\"empty-icon\">📊</div>\r\n <div class=\"empty-text\">执行查询后,结果将显示在这里</div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"status-bar\">\r\n <div class=\"status-item\">\r\n <span class=\"status-icon\">🔗</span>\r\n <span>{{ selectedConnection?.name || '未选择连接' }}</span>\r\n </div>\r\n <div class=\"status-item\">\r\n <span id=\"statusTime\">{{ queryResults ? `执行时间: ${queryResults.executionTime}ms` : '' }}</span>\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script setup lang=\"ts\">\r\nimport { ref, reactive, computed, onMounted } from 'vue';\r\nimport { getVSCodeBridge } from '../bridge';\r\n\r\nconst vscode = getVSCodeBridge();\r\n\r\nconst connections = ref<any[]>([]);\r\nconst selectedConnectionId = ref('');\r\nconst queryText = ref('');\r\nconst queryResults = ref<any>(null);\r\nconst loading = ref(false);\r\nconst queryTextarea = ref<HTMLTextAreaElement | null>(null);\r\n\r\nconst selectedConnection = computed(() => {\r\n return connections.value.find(c => c.id === selectedConnectionId.value);\r\n});\r\n\r\nonMounted(() => {\r\n // 请求连接列表\r\n vscode.postMessage({ command: 'getConnections' });\r\n\r\n // 监听来自扩展的消息\r\n vscode.onMessage((message: any) => {\r\n if (message.command === 'connections') {\r\n connections.value = message.data;\r\n } else if (message.command === 'queryResult') {\r\n displayQueryResult(message.data);\r\n } else if (message.command === 'error') {\r\n handleError(message.data);\r\n }\r\n });\r\n});\r\n\r\nfunction handleConnectionChange() {\r\n // 连接变化时的处理\r\n}\r\n\r\nfunction handleKeydown(e: KeyboardEvent) {\r\n // Ctrl+Enter 或 Cmd+Enter 执行查询\r\n if ((e.ctrlKey || e.metaKey) && e.key === 'Enter') {\r\n e.preventDefault();\r\n executeQuery();\r\n }\r\n\r\n // Tab 键插入2个空格\r\n if (e.key === 'Tab') {\r\n e.preventDefault();\r\n const textarea = queryTextarea.value;\r\n if (textarea) {\r\n const start = textarea.selectionStart;\r\n const end = textarea.selectionEnd;\r\n queryText.value = queryText.value.substring(0, start) + ' ' + queryText.value.substring(end);\r\n textarea.selectionStart = textarea.selectionEnd = start + 2;\r\n }\r\n }\r\n}\r\n\r\nfunction executeQuery() {\r\n if (!selectedConnectionId.value) {\r\n alert('请先选择数据库连接');\r\n return;\r\n }\r\n\r\n if (!queryText.value.trim()) {\r\n alert('请输入 SQL 查询语句');\r\n return;\r\n }\r\n\r\n loading.value = true;\r\n\r\n vscode.postMessage({\r\n command: 'executeQuery',\r\n data: {\r\n connectionId: selectedConnectionId.value,\r\n sql: queryText.value\r\n }\r\n });\r\n}\r\n\r\nfunction clearQuery() {\r\n queryText.value = '';\r\n queryResults.value = null;\r\n}\r\n\r\nfunction displayQueryResult(data: any) {\r\n queryResults.value = data;\r\n loading.value = false;\r\n}\r\n\r\nfunction handleError(error: string) {\r\n loading.value = false;\r\n alert(`查询错误: ${error}`);\r\n}\r\n\r\nfunction formatCell(cell: any) {\r\n if (cell === null || cell === undefined) {\r\n return 'NULL';\r\n }\r\n if (typeof cell === 'boolean') {\r\n return cell ? '✓' : '✗';\r\n }\r\n if (typeof cell === 'object') {\r\n return JSON.stringify(cell);\r\n }\r\n return String(cell);\r\n}\r\n</script>\r\n\r\n<style scoped>\r\n.query-panel {\r\n display: flex;\r\n flex-direction: column;\r\n height: 100vh;\r\n overflow: hidden;\r\n}\r\n\r\n.query-toolbar {\r\n display: flex;\r\n align-items: center;\r\n gap: 12px;\r\n padding: 12px;\r\n background-color: var(--vscode-editorGroupHeader-tabsBackground);\r\n border-bottom: 1px solid var(--vscode-panel-border);\r\n}\r\n\r\n.query-selector {\r\n min-width: 200px;\r\n padding: 6px 10px;\r\n border: 1px solid var(--vscode-input-border);\r\n background-color: var(--vscode-input-background);\r\n color: var(--vscode-input-foreground);\r\n border-radius: 4px;\r\n}\r\n\r\n.btn {\r\n padding: 6px 14px;\r\n border: none;\r\n border-radius: 4px;\r\n font-size: 13px;\r\n cursor: pointer;\r\n transition: background-color 0.2s;\r\n}\r\n\r\n.btn-primary {\r\n background-color: var(--vscode-button-background);\r\n color: var(--vscode-button-foreground);\r\n}\r\n\r\n.btn-primary:hover {\r\n background-color: var(--vscode-button-hoverBackground);\r\n}\r\n\r\n.btn-secondary {\r\n background-color: var(--vscode-button-secondaryBackground);\r\n color: var(--vscode-button-secondaryForeground);\r\n}\r\n\r\n.btn-secondary:hover {\r\n background-color: var(--vscode-button-secondaryHoverBackground);\r\n}\r\n\r\n.query-editor {\r\n flex: 1;\r\n display: flex;\r\n flex-direction: column;\r\n border-bottom: 1px solid var(--vscode-panel-border);\r\n min-height: 200px;\r\n}\r\n\r\n.query-textarea {\r\n flex: 1;\r\n padding: 16px;\r\n font-family: var(--vscode-editor-font-family, 'Consolas', 'Monaco', monospace);\r\n font-size: 14px;\r\n line-height: 1.6;\r\n border: none;\r\n resize: none;\r\n background-color: var(--vscode-editor-background);\r\n color: var(--vscode-editor-foreground);\r\n}\r\n\r\n.query-textarea:focus {\r\n outline: none;\r\n}\r\n\r\n.query-results {\r\n flex: 1;\r\n overflow: auto;\r\n padding: 12px;\r\n}\r\n\r\n.loading-state {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n padding: 40px;\r\n gap: 12px;\r\n}\r\n\r\n.spinner {\r\n width: 20px;\r\n height: 20px;\r\n border: 2px solid var(--vscode-progressBar-background);\r\n border-top-color: var(--vscode-progressBar-foreground);\r\n border-radius: 50%;\r\n animation: spin 0.6s linear infinite;\r\n}\r\n\r\n@keyframes spin {\r\n to {\r\n transform: rotate(360deg);\r\n }\r\n}\r\n\r\n.results-header {\r\n display: flex;\r\n justify-content: space-between;\r\n align-items: center;\r\n margin-bottom: 12px;\r\n padding: 8px 12px;\r\n background-color: var(--vscode-editorGroupHeader-tabsBackground);\r\n border-radius: 4px;\r\n}\r\n\r\n.results-title {\r\n font-size: 14px;\r\n font-weight: 600;\r\n}\r\n\r\n.results-meta {\r\n font-size: 12px;\r\n color: var(--vscode-descriptionForeground);\r\n}\r\n\r\n.data-table {\r\n width: 100%;\r\n border-collapse: collapse;\r\n font-size: 13px;\r\n}\r\n\r\n.data-table th,\r\n.data-table td {\r\n padding: 8px 12px;\r\n text-align: left;\r\n border-bottom: 1px solid var(--vscode-panel-border);\r\n}\r\n\r\n.data-table th {\r\n background-color: var(--vscode-editorGroupHeader-tabsBackground);\r\n font-weight: 600;\r\n position: sticky;\r\n top: 0;\r\n}\r\n\r\n.data-table tbody tr:hover {\r\n background-color: var(--vscode-list-hoverBackground);\r\n}\r\n\r\n.empty-state {\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n padding: 60px 20px;\r\n text-align: center;\r\n}\r\n\r\n.empty-icon {\r\n font-size: 48px;\r\n margin-bottom: 16px;\r\n opacity: 0.5;\r\n}\r\n\r\n.empty-text {\r\n font-size: 14px;\r\n color: var(--vscode-descriptionForeground);\r\n}\r\n\r\n.status-bar {\r\n display: flex;\r\n justify-content: space-between;\r\n align-items: center;\r\n padding: 8px 12px;\r\n background-color: var(--vscode-statusBar-background);\r\n color: var(--vscode-statusBar-foreground);\r\n font-size: 12px;\r\n}\r\n\r\n.status-item {\r\n display: flex;\r\n align-items: center;\r\n gap: 8px;\r\n}\r\n\r\n.status-icon {\r\n color: var(--vscode-textLink-foreground);\r\n}\r\n</style>\r\n","/**\r\n * VSCode WebView - Query Entry Point\r\n * SQL 查询面板入口\r\n */\r\n\r\nimport { createApp } from 'vue';\r\nimport QueryPanel from '../components/QueryPanel.vue';\r\n\r\n// 创建 Vue 应用\r\nconst app = createApp(QueryPanel);\r\n\r\n// 挂载\r\napp.mount('#app');\r\n"],"names":["_openBlock","_createElementBlock","_createElementVNode","_Fragment","_renderList","_toDisplayString"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"base.service.js","sourceRoot":"","sources":["base.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,363 +0,0 @@
|
|
|
1
|
-
import { DataSource } from 'typeorm';
|
|
2
|
-
import {
|
|
3
|
-
DatabaseEntity,
|
|
4
|
-
TableEntity,
|
|
5
|
-
ColumnEntity,
|
|
6
|
-
IndexEntity,
|
|
7
|
-
ForeignKeyEntity
|
|
8
|
-
} from './model/database.entity';
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* 数据库服务基础类
|
|
12
|
-
* 提供所有数据库类型的通用操作
|
|
13
|
-
*/
|
|
14
|
-
export abstract class BaseDatabaseService {
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* 获取数据库类型
|
|
18
|
-
*/
|
|
19
|
-
abstract getDatabaseType(): string;
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* 获取数据库列表 - 子类实现
|
|
23
|
-
*/
|
|
24
|
-
abstract getDatabases(dataSource: DataSource): Promise<string[]>;
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* 获取表列表 - 子类实现
|
|
28
|
-
*/
|
|
29
|
-
abstract getTables(dataSource: DataSource, database: string): Promise<TableEntity[]>;
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* 获取列信息 - 子类实现
|
|
33
|
-
*/
|
|
34
|
-
abstract getColumns(dataSource: DataSource, database: string, table: string): Promise<ColumnEntity[]>;
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* 获取索引信息 - 子类实现
|
|
38
|
-
*/
|
|
39
|
-
abstract getIndexes(dataSource: DataSource, database: string, table: string): Promise<IndexEntity[]>;
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* 获取外键信息 - 子类实现
|
|
43
|
-
*/
|
|
44
|
-
abstract getForeignKeys(dataSource: DataSource, database: string, table: string): Promise<ForeignKeyEntity[]>;
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* 获取数据库大小 - 子类实现
|
|
48
|
-
*/
|
|
49
|
-
abstract getDatabaseSize(dataSource: DataSource, database: string): Promise<number>;
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* 通用方法:获取数据库详细信息
|
|
53
|
-
*/
|
|
54
|
-
async getDatabaseInfo(dataSource: DataSource, databaseName: string): Promise<DatabaseEntity> {
|
|
55
|
-
const tables = await this.getTables(dataSource, databaseName);
|
|
56
|
-
|
|
57
|
-
return {
|
|
58
|
-
name: databaseName,
|
|
59
|
-
tableCount: tables.length,
|
|
60
|
-
size: await this.getDatabaseSize(dataSource, databaseName),
|
|
61
|
-
tables
|
|
62
|
-
};
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
/**
|
|
66
|
-
* 通用方法:获取表详细信息
|
|
67
|
-
*/
|
|
68
|
-
async getTableInfo(dataSource: DataSource, databaseName: string, tableName: string): Promise<TableEntity> {
|
|
69
|
-
const tables = await this.getTables(dataSource, databaseName);
|
|
70
|
-
const table = tables.find(t => t.name === tableName);
|
|
71
|
-
|
|
72
|
-
if (!table) {
|
|
73
|
-
throw new Error(`表 ${tableName} 不存在`);
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
// 获取列信息
|
|
77
|
-
table.columns = await this.getColumns(dataSource, databaseName, tableName);
|
|
78
|
-
|
|
79
|
-
// 获取索引信息
|
|
80
|
-
table.indexes = await this.getIndexes(dataSource, databaseName, tableName);
|
|
81
|
-
|
|
82
|
-
// 获取外键信息
|
|
83
|
-
table.foreignKeys = await this.getForeignKeys(dataSource, databaseName, tableName);
|
|
84
|
-
|
|
85
|
-
return table;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
/**
|
|
89
|
-
* 通用方法:获取表数据
|
|
90
|
-
*/
|
|
91
|
-
async getTableData(
|
|
92
|
-
dataSource: DataSource,
|
|
93
|
-
databaseName: string,
|
|
94
|
-
tableName: string,
|
|
95
|
-
page: number = 1,
|
|
96
|
-
pageSize: number = 100,
|
|
97
|
-
where?: string,
|
|
98
|
-
orderBy?: string
|
|
99
|
-
): Promise<{ data: any[], total: number }> {
|
|
100
|
-
// 构建查询
|
|
101
|
-
let query = `SELECT * FROM ${this.quoteIdentifier(tableName)}`;
|
|
102
|
-
|
|
103
|
-
if (where) {
|
|
104
|
-
query += ` WHERE ${where}`;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
if (orderBy) {
|
|
108
|
-
query += ` ORDER BY ${orderBy}`;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
const offset = (page - 1) * pageSize;
|
|
112
|
-
query += ` LIMIT ${pageSize} OFFSET ${offset}`;
|
|
113
|
-
|
|
114
|
-
// 执行数据查询
|
|
115
|
-
const data = await dataSource.query(query);
|
|
116
|
-
|
|
117
|
-
// 获取总数
|
|
118
|
-
let countQuery = `SELECT COUNT(*) as total FROM ${this.quoteIdentifier(tableName)}`;
|
|
119
|
-
if (where) {
|
|
120
|
-
countQuery += ` WHERE ${where}`;
|
|
121
|
-
}
|
|
122
|
-
const countResult = await dataSource.query(countQuery);
|
|
123
|
-
const total = countResult[0]?.total || 0;
|
|
124
|
-
|
|
125
|
-
return { data, total };
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
/**
|
|
129
|
-
* 通用方法:执行SQL查询
|
|
130
|
-
*/
|
|
131
|
-
async executeQuery(dataSource: DataSource, sql: string): Promise<any> {
|
|
132
|
-
try {
|
|
133
|
-
const result = await dataSource.query(sql);
|
|
134
|
-
return result;
|
|
135
|
-
} catch (error) {
|
|
136
|
-
console.error('SQL执行失败:', error);
|
|
137
|
-
throw error;
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
/**
|
|
142
|
-
* 批量执行SQL查询(支持多条语句)
|
|
143
|
-
*/
|
|
144
|
-
async executeBatchQuery(
|
|
145
|
-
dataSource: DataSource,
|
|
146
|
-
sqlStatements: string[],
|
|
147
|
-
options?: {
|
|
148
|
-
batchSize?: number; // 每批执行的语句数量
|
|
149
|
-
useTransaction?: boolean; // 是否使用事务
|
|
150
|
-
continueOnError?: boolean; // 错误时是否继续执行
|
|
151
|
-
}
|
|
152
|
-
): Promise<{ success: number; failed: number; errors: any[] }> {
|
|
153
|
-
const {
|
|
154
|
-
batchSize = 100,
|
|
155
|
-
useTransaction = true,
|
|
156
|
-
continueOnError = false
|
|
157
|
-
} = options || {};
|
|
158
|
-
|
|
159
|
-
let success = 0;
|
|
160
|
-
let failed = 0;
|
|
161
|
-
const errors: any[] = [];
|
|
162
|
-
|
|
163
|
-
// 分批处理SQL语句
|
|
164
|
-
for (let i = 0; i < sqlStatements.length; i += batchSize) {
|
|
165
|
-
const batch = sqlStatements.slice(i, i + batchSize);
|
|
166
|
-
|
|
167
|
-
try {
|
|
168
|
-
if (useTransaction) {
|
|
169
|
-
// 使用事务执行批次
|
|
170
|
-
await dataSource.transaction(async (manager) => {
|
|
171
|
-
for (const statement of batch) {
|
|
172
|
-
try {
|
|
173
|
-
await manager.query(statement);
|
|
174
|
-
success++;
|
|
175
|
-
} catch (error) {
|
|
176
|
-
failed++;
|
|
177
|
-
errors.push({ statement, error: error.message });
|
|
178
|
-
if (!continueOnError) {
|
|
179
|
-
throw error;
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
});
|
|
184
|
-
} else {
|
|
185
|
-
// 非事务执行批次
|
|
186
|
-
for (const statement of batch) {
|
|
187
|
-
try {
|
|
188
|
-
await dataSource.query(statement);
|
|
189
|
-
success++;
|
|
190
|
-
} catch (error) {
|
|
191
|
-
failed++;
|
|
192
|
-
errors.push({ statement, error: error.message });
|
|
193
|
-
if (!continueOnError) {
|
|
194
|
-
throw error;
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
} catch (batchError) {
|
|
200
|
-
console.error(`批次执行失败 (${i}-${i + batchSize}):`, batchError);
|
|
201
|
-
if (!continueOnError) {
|
|
202
|
-
throw new Error(`批次执行失败: ${batchError.message}`);
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
return { success, failed, errors };
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
/**
|
|
211
|
-
* 执行文件中的SQL(支持大文件)
|
|
212
|
-
*/
|
|
213
|
-
async executeSqlFile(
|
|
214
|
-
dataSource: DataSource,
|
|
215
|
-
filePath: string,
|
|
216
|
-
options?: {
|
|
217
|
-
batchSize?: number;
|
|
218
|
-
useTransaction?: boolean;
|
|
219
|
-
continueOnError?: boolean;
|
|
220
|
-
}
|
|
221
|
-
): Promise<{ success: number; failed: number; errors: any[] }> {
|
|
222
|
-
const fs = require('fs');
|
|
223
|
-
const sqlContent = fs.readFileSync(filePath, 'utf8');
|
|
224
|
-
|
|
225
|
-
// 分割SQL语句
|
|
226
|
-
const sqlStatements = sqlContent
|
|
227
|
-
.split(';')
|
|
228
|
-
.map(statement => statement.trim())
|
|
229
|
-
.filter(statement => statement.length > 0);
|
|
230
|
-
|
|
231
|
-
return this.executeBatchQuery(dataSource, sqlStatements, options);
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
/**
|
|
235
|
-
* 通用方法:测试连接
|
|
236
|
-
*/
|
|
237
|
-
async testConnection(dataSource: DataSource): Promise<boolean> {
|
|
238
|
-
try {
|
|
239
|
-
await dataSource.query('SELECT 1');
|
|
240
|
-
return true;
|
|
241
|
-
} catch (error) {
|
|
242
|
-
//this.ctx.logger.error('数据库连接测试失败:', error);
|
|
243
|
-
console.error(error);
|
|
244
|
-
return false;
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
|
|
248
|
-
/**
|
|
249
|
-
* 通用方法:给标识符加引号
|
|
250
|
-
*/
|
|
251
|
-
public quoteIdentifier(identifier: string): string {
|
|
252
|
-
return `"${identifier}"`;
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
/**
|
|
256
|
-
* 通用方法:构建分页查询
|
|
257
|
-
*/
|
|
258
|
-
protected buildPaginationQuery(baseQuery: string, page: number, pageSize: number): string {
|
|
259
|
-
const offset = (page - 1) * pageSize;
|
|
260
|
-
return `${baseQuery} LIMIT ${pageSize} OFFSET ${offset}`;
|
|
261
|
-
}
|
|
262
|
-
|
|
263
|
-
/**
|
|
264
|
-
* 通用方法:构建计数查询
|
|
265
|
-
*/
|
|
266
|
-
protected buildCountQuery(baseQuery: string): string {
|
|
267
|
-
return `SELECT COUNT(*) as total FROM (${baseQuery}) as count_query`;
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
/**
|
|
271
|
-
* 获取视图列表 - 子类实现(如果支持)
|
|
272
|
-
*/
|
|
273
|
-
async getViews(dataSource: DataSource, database: string): Promise<any[]> {
|
|
274
|
-
// 默认实现,子类可以重写
|
|
275
|
-
throw new Error(`数据库类型 ${this.getDatabaseType()} 不支持视图`);
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
/**
|
|
279
|
-
* 获取视图定义 - 子类实现(如果支持)
|
|
280
|
-
*/
|
|
281
|
-
async getViewDefinition(dataSource: DataSource, database: string, viewName: string): Promise<string> {
|
|
282
|
-
// 默认实现,子类可以重写
|
|
283
|
-
throw new Error(`数据库类型 ${this.getDatabaseType()} 不支持视图`);
|
|
284
|
-
}
|
|
285
|
-
|
|
286
|
-
/**
|
|
287
|
-
* 获取存储过程列表 - 子类实现(如果支持)
|
|
288
|
-
*/
|
|
289
|
-
async getProcedures(dataSource: DataSource, database: string): Promise<any[]> {
|
|
290
|
-
// 默认实现,子类可以重写
|
|
291
|
-
throw new Error(`数据库类型 ${this.getDatabaseType()} 不支持存储过程`);
|
|
292
|
-
}
|
|
293
|
-
|
|
294
|
-
/**
|
|
295
|
-
* 获取存储过程定义 - 子类实现(如果支持)
|
|
296
|
-
*/
|
|
297
|
-
async getProcedureDefinition(dataSource: DataSource, database: string, procedureName: string): Promise<string> {
|
|
298
|
-
// 默认实现,子类可以重写
|
|
299
|
-
throw new Error(`数据库类型 ${this.getDatabaseType()} 不支持存储过程`);
|
|
300
|
-
}
|
|
301
|
-
|
|
302
|
-
/**
|
|
303
|
-
* 导出数据库架构 - 子类实现
|
|
304
|
-
*/
|
|
305
|
-
abstract exportSchema(dataSource: DataSource, database: string): Promise<string>;
|
|
306
|
-
|
|
307
|
-
/**
|
|
308
|
-
* 查看数据库日志 - 子类实现(如果支持)
|
|
309
|
-
*/
|
|
310
|
-
abstract viewLogs(dataSource: DataSource, database?: string, limit?: number): Promise<any[]>;
|
|
311
|
-
|
|
312
|
-
/**
|
|
313
|
-
* 创建数据库 - 子类实现(如果支持)
|
|
314
|
-
*/
|
|
315
|
-
async createDatabase(dataSource: DataSource, databaseName: string, options?: any): Promise<void> {
|
|
316
|
-
// 默认实现,子类可以重写
|
|
317
|
-
throw new Error(`数据库类型 ${this.getDatabaseType()} 不支持创建数据库`);
|
|
318
|
-
}
|
|
319
|
-
|
|
320
|
-
/**
|
|
321
|
-
* 删除数据库 - 子类实现(如果支持)
|
|
322
|
-
*/
|
|
323
|
-
async dropDatabase(dataSource: DataSource, databaseName: string): Promise<void> {
|
|
324
|
-
// 默认实现,子类可以重写
|
|
325
|
-
throw new Error(`数据库类型 ${this.getDatabaseType()} 不支持删除数据库`);
|
|
326
|
-
}
|
|
327
|
-
|
|
328
|
-
/**
|
|
329
|
-
* 备份数据库 - 子类实现(如果支持)
|
|
330
|
-
*/
|
|
331
|
-
async backupDatabase(dataSource: DataSource, databaseName: string, options?: any): Promise<string> {
|
|
332
|
-
// 默认实现,子类可以重写
|
|
333
|
-
throw new Error(`数据库类型 ${this.getDatabaseType()} 不支持备份数据库`);
|
|
334
|
-
}
|
|
335
|
-
|
|
336
|
-
/**
|
|
337
|
-
* 恢复数据库 - 子类实现(如果支持)
|
|
338
|
-
*/
|
|
339
|
-
async restoreDatabase(dataSource: DataSource, databaseName: string, filePath: string, options?: any): Promise<void> {
|
|
340
|
-
// 默认实现,子类可以重写
|
|
341
|
-
throw new Error(`数据库类型 ${this.getDatabaseType()} 不支持恢复数据库`);
|
|
342
|
-
}
|
|
343
|
-
|
|
344
|
-
/**
|
|
345
|
-
* 导出表数据到 SQL 文件 - 子类实现
|
|
346
|
-
*/
|
|
347
|
-
abstract exportTableDataToSQL(dataSource: DataSource, databaseName: string, tableName: string, options?: any): Promise<string>;
|
|
348
|
-
|
|
349
|
-
/**
|
|
350
|
-
* 导出表数据到 CSV 文件 - 子类实现
|
|
351
|
-
*/
|
|
352
|
-
abstract exportTableDataToCSV(dataSource: DataSource, databaseName: string, tableName: string, options?: any): Promise<string>;
|
|
353
|
-
|
|
354
|
-
/**
|
|
355
|
-
* 导出表数据到 JSON 文件 - 子类实现
|
|
356
|
-
*/
|
|
357
|
-
abstract exportTableDataToJSON(dataSource: DataSource, databaseName: string, tableName: string, options?: any): Promise<string>;
|
|
358
|
-
|
|
359
|
-
/**
|
|
360
|
-
* 导出表数据到 Excel 文件 - 子类实现
|
|
361
|
-
*/
|
|
362
|
-
abstract exportTableDataToExcel(dataSource: DataSource, databaseName: string, tableName: string, options?: any): Promise<string>;
|
|
363
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cockroachdb.service.js","sourceRoot":"","sources":["cockroachdb.service.ts"],"names":[],"mappings":"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"}
|