@zhin.js/database 1.0.0
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/LICENSE +21 -0
- package/README.md +93 -0
- package/lib/base/database.d.ts +71 -0
- package/lib/base/database.d.ts.map +1 -0
- package/lib/base/database.js +101 -0
- package/lib/base/database.js.map +1 -0
- package/lib/base/dialect.d.ts +34 -0
- package/lib/base/dialect.d.ts.map +1 -0
- package/lib/base/dialect.js +21 -0
- package/lib/base/dialect.js.map +1 -0
- package/lib/base/index.d.ts +6 -0
- package/lib/base/index.d.ts.map +1 -0
- package/lib/base/index.js +6 -0
- package/lib/base/index.js.map +1 -0
- package/lib/base/model.d.ts +53 -0
- package/lib/base/model.d.ts.map +1 -0
- package/lib/base/model.js +65 -0
- package/lib/base/model.js.map +1 -0
- package/lib/base/query-classes.d.ts +68 -0
- package/lib/base/query-classes.d.ts.map +1 -0
- package/lib/base/query-classes.js +178 -0
- package/lib/base/query-classes.js.map +1 -0
- package/lib/base/thenable.d.ts +15 -0
- package/lib/base/thenable.d.ts.map +1 -0
- package/lib/base/thenable.js +33 -0
- package/lib/base/thenable.js.map +1 -0
- package/lib/dialects/memory.d.ts +52 -0
- package/lib/dialects/memory.d.ts.map +1 -0
- package/lib/dialects/memory.js +772 -0
- package/lib/dialects/memory.js.map +1 -0
- package/lib/dialects/mongodb.d.ts +85 -0
- package/lib/dialects/mongodb.d.ts.map +1 -0
- package/lib/dialects/mongodb.js +461 -0
- package/lib/dialects/mongodb.js.map +1 -0
- package/lib/dialects/mysql.d.ts +33 -0
- package/lib/dialects/mysql.d.ts.map +1 -0
- package/lib/dialects/mysql.js +132 -0
- package/lib/dialects/mysql.js.map +1 -0
- package/lib/dialects/pg.d.ts +33 -0
- package/lib/dialects/pg.d.ts.map +1 -0
- package/lib/dialects/pg.js +132 -0
- package/lib/dialects/pg.js.map +1 -0
- package/lib/dialects/redis.d.ts +87 -0
- package/lib/dialects/redis.d.ts.map +1 -0
- package/lib/dialects/redis.js +500 -0
- package/lib/dialects/redis.js.map +1 -0
- package/lib/dialects/sqlite.d.ts +46 -0
- package/lib/dialects/sqlite.d.ts.map +1 -0
- package/lib/dialects/sqlite.js +201 -0
- package/lib/dialects/sqlite.js.map +1 -0
- package/lib/index.d.ts +18 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +18 -0
- package/lib/index.js.map +1 -0
- package/lib/registry.d.ts +37 -0
- package/lib/registry.d.ts.map +1 -0
- package/lib/registry.js +21 -0
- package/lib/registry.js.map +1 -0
- package/lib/type/document/database.d.ts +60 -0
- package/lib/type/document/database.d.ts.map +1 -0
- package/lib/type/document/database.js +242 -0
- package/lib/type/document/database.js.map +1 -0
- package/lib/type/document/model.d.ts +42 -0
- package/lib/type/document/model.d.ts.map +1 -0
- package/lib/type/document/model.js +65 -0
- package/lib/type/document/model.js.map +1 -0
- package/lib/type/keyvalue/database.d.ts +64 -0
- package/lib/type/keyvalue/database.d.ts.map +1 -0
- package/lib/type/keyvalue/database.js +214 -0
- package/lib/type/keyvalue/database.js.map +1 -0
- package/lib/type/keyvalue/model.d.ts +107 -0
- package/lib/type/keyvalue/model.d.ts.map +1 -0
- package/lib/type/keyvalue/model.js +261 -0
- package/lib/type/keyvalue/model.js.map +1 -0
- package/lib/type/related/database.d.ts +32 -0
- package/lib/type/related/database.d.ts.map +1 -0
- package/lib/type/related/database.js +334 -0
- package/lib/type/related/database.js.map +1 -0
- package/lib/type/related/model.d.ts +43 -0
- package/lib/type/related/model.d.ts.map +1 -0
- package/lib/type/related/model.js +108 -0
- package/lib/type/related/model.js.map +1 -0
- package/lib/types.d.ts +251 -0
- package/lib/types.d.ts.map +1 -0
- package/lib/types.js +28 -0
- package/lib/types.js.map +1 -0
- package/package.json +54 -0
- package/src/base/database.ts +128 -0
- package/src/base/dialect.ts +76 -0
- package/src/base/index.ts +5 -0
- package/src/base/model.ts +89 -0
- package/src/base/query-classes.ts +217 -0
- package/src/base/thenable.ts +54 -0
- package/src/dialects/memory.ts +880 -0
- package/src/dialects/mongodb.ts +533 -0
- package/src/dialects/mysql.ts +157 -0
- package/src/dialects/pg.ts +157 -0
- package/src/dialects/redis.ts +598 -0
- package/src/dialects/sqlite.ts +233 -0
- package/src/index.ts +20 -0
- package/src/registry.ts +59 -0
- package/src/type/document/database.ts +283 -0
- package/src/type/document/model.ts +86 -0
- package/src/type/keyvalue/database.ts +261 -0
- package/src/type/keyvalue/model.ts +339 -0
- package/src/type/related/database.ts +392 -0
- package/src/type/related/model.ts +117 -0
- package/src/types.ts +403 -0
- package/tsconfig.json +24 -0
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
import { Dialect } from "../base";
|
|
2
|
+
import { Registry } from "../registry";
|
|
3
|
+
import { RelatedDatabase } from "../type/related/database";
|
|
4
|
+
export class SQLiteDialect extends Dialect {
|
|
5
|
+
db = null;
|
|
6
|
+
constructor(config) {
|
|
7
|
+
super('sqlite', config);
|
|
8
|
+
}
|
|
9
|
+
// Connection management
|
|
10
|
+
isConnected() {
|
|
11
|
+
return this.db !== null;
|
|
12
|
+
}
|
|
13
|
+
async connect() {
|
|
14
|
+
try {
|
|
15
|
+
const { default: sqlite3 } = await import('sqlite3');
|
|
16
|
+
this.db = new sqlite3.Database(this.config.filename);
|
|
17
|
+
}
|
|
18
|
+
catch (error) {
|
|
19
|
+
console.error('forgot install sqlite3 ?');
|
|
20
|
+
throw new Error(`SQLite 连接失败: ${error}`);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
async disconnect() {
|
|
24
|
+
this.db = null;
|
|
25
|
+
}
|
|
26
|
+
async healthCheck() {
|
|
27
|
+
return this.isConnected();
|
|
28
|
+
}
|
|
29
|
+
async query(sql, params) {
|
|
30
|
+
return new Promise((resolve, reject) => {
|
|
31
|
+
this.db.all(sql, params, (err, rows) => {
|
|
32
|
+
if (err) {
|
|
33
|
+
reject(err);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
// 对查询结果进行后处理,移除多余的引号
|
|
37
|
+
const processedRows = this.processQueryResults(rows);
|
|
38
|
+
resolve(processedRows);
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
this.db.get(sql, params, (err, row) => {
|
|
42
|
+
if (err) {
|
|
43
|
+
reject(err);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
// 对单行结果进行后处理
|
|
47
|
+
const processedRow = this.processQueryResults(row);
|
|
48
|
+
resolve(processedRow);
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* 处理查询结果,移除字符串字段的多余引号
|
|
55
|
+
*/
|
|
56
|
+
processQueryResults(data) {
|
|
57
|
+
if (!data)
|
|
58
|
+
return data;
|
|
59
|
+
if (Array.isArray(data)) {
|
|
60
|
+
return data.map(row => this.processRowData(row));
|
|
61
|
+
}
|
|
62
|
+
else if (typeof data === 'object') {
|
|
63
|
+
return this.processRowData(data);
|
|
64
|
+
}
|
|
65
|
+
return data;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* 处理单行数据
|
|
69
|
+
*/
|
|
70
|
+
processRowData(row) {
|
|
71
|
+
if (!row || typeof row !== 'object')
|
|
72
|
+
return row;
|
|
73
|
+
const processedRow = {};
|
|
74
|
+
for (const [key, value] of Object.entries(row)) {
|
|
75
|
+
processedRow[key] = this.processFieldValue(value);
|
|
76
|
+
}
|
|
77
|
+
return processedRow;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* 处理字段值,移除多余的引号并解析 JSON
|
|
81
|
+
*/
|
|
82
|
+
processFieldValue(value) {
|
|
83
|
+
if (typeof value !== 'string')
|
|
84
|
+
return value;
|
|
85
|
+
// 移除字符串两端的引号(如果存在)
|
|
86
|
+
if ((value.startsWith("'") && value.endsWith("'")) ||
|
|
87
|
+
(value.startsWith('"') && value.endsWith('"'))) {
|
|
88
|
+
const unquoted = value.slice(1, -1);
|
|
89
|
+
// 尝试解析为 JSON(用于 json 类型字段)
|
|
90
|
+
if (unquoted.startsWith('{') || unquoted.startsWith('[')) {
|
|
91
|
+
try {
|
|
92
|
+
return JSON.parse(unquoted);
|
|
93
|
+
}
|
|
94
|
+
catch {
|
|
95
|
+
// 如果解析失败,返回去除引号的字符串
|
|
96
|
+
return unquoted;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
return unquoted;
|
|
100
|
+
}
|
|
101
|
+
return value;
|
|
102
|
+
}
|
|
103
|
+
async dispose() {
|
|
104
|
+
if (this.db) {
|
|
105
|
+
await this.db.close();
|
|
106
|
+
this.db = null;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
// SQL generation methods
|
|
110
|
+
mapColumnType(type) {
|
|
111
|
+
const typeMap = {
|
|
112
|
+
'text': 'TEXT',
|
|
113
|
+
'integer': 'INTEGER',
|
|
114
|
+
'float': 'REAL',
|
|
115
|
+
'boolean': 'INTEGER',
|
|
116
|
+
'date': 'TEXT',
|
|
117
|
+
'json': 'TEXT'
|
|
118
|
+
};
|
|
119
|
+
return typeMap[type.toLowerCase()] || 'TEXT';
|
|
120
|
+
}
|
|
121
|
+
quoteIdentifier(identifier) {
|
|
122
|
+
return `"${identifier}"`;
|
|
123
|
+
}
|
|
124
|
+
getParameterPlaceholder(index) {
|
|
125
|
+
return '?';
|
|
126
|
+
}
|
|
127
|
+
getStatementTerminator() {
|
|
128
|
+
return ';';
|
|
129
|
+
}
|
|
130
|
+
formatBoolean(value) {
|
|
131
|
+
return value ? '1' : '0';
|
|
132
|
+
}
|
|
133
|
+
formatDate(value) {
|
|
134
|
+
return `'${value.toISOString()}'`;
|
|
135
|
+
}
|
|
136
|
+
formatJson(value) {
|
|
137
|
+
return `'${JSON.stringify(value).replace(/'/g, "''")}'`;
|
|
138
|
+
}
|
|
139
|
+
escapeString(value) {
|
|
140
|
+
return value.replace(/'/g, "''");
|
|
141
|
+
}
|
|
142
|
+
formatDefaultValue(value) {
|
|
143
|
+
if (typeof value === 'string') {
|
|
144
|
+
return `'${this.escapeString(value)}'`;
|
|
145
|
+
}
|
|
146
|
+
else if (typeof value === 'number' || typeof value === 'boolean') {
|
|
147
|
+
return value.toString();
|
|
148
|
+
}
|
|
149
|
+
else if (value instanceof Date) {
|
|
150
|
+
return this.formatDate(value);
|
|
151
|
+
}
|
|
152
|
+
else if (value === null) {
|
|
153
|
+
return 'NULL';
|
|
154
|
+
}
|
|
155
|
+
else if (typeof value === 'object') {
|
|
156
|
+
return this.formatJson(value);
|
|
157
|
+
}
|
|
158
|
+
else {
|
|
159
|
+
throw new Error(`Unsupported default value type: ${typeof value}`);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
formatLimit(limit) {
|
|
163
|
+
return `LIMIT ${limit}`;
|
|
164
|
+
}
|
|
165
|
+
formatOffset(offset) {
|
|
166
|
+
return `OFFSET ${offset}`;
|
|
167
|
+
}
|
|
168
|
+
formatLimitOffset(limit, offset) {
|
|
169
|
+
return `LIMIT ${limit} OFFSET ${offset}`;
|
|
170
|
+
}
|
|
171
|
+
formatCreateTable(tableName, columns) {
|
|
172
|
+
return `CREATE TABLE IF NOT EXISTS ${this.quoteIdentifier(tableName)} (${columns.join(', ')})`;
|
|
173
|
+
}
|
|
174
|
+
formatColumnDefinition(field, column) {
|
|
175
|
+
const name = this.quoteIdentifier(String(field));
|
|
176
|
+
const type = this.mapColumnType(column.type);
|
|
177
|
+
const length = column.length ? `(${column.length})` : '';
|
|
178
|
+
const nullable = column.nullable === false ? ' NOT NULL' : '';
|
|
179
|
+
const primary = column.primary ? ' PRIMARY KEY' : '';
|
|
180
|
+
const unique = column.unique ? ' UNIQUE' : '';
|
|
181
|
+
const defaultVal = column.default !== undefined
|
|
182
|
+
? ` DEFAULT ${this.formatDefaultValue(column.default)}`
|
|
183
|
+
: '';
|
|
184
|
+
return `${name} ${type}${length}${primary}${unique}${nullable}${defaultVal}`;
|
|
185
|
+
}
|
|
186
|
+
formatAlterTable(tableName, alterations) {
|
|
187
|
+
return `ALTER TABLE ${this.quoteIdentifier(tableName)} ${alterations.join(', ')}`;
|
|
188
|
+
}
|
|
189
|
+
formatDropTable(tableName, ifExists) {
|
|
190
|
+
const ifExistsClause = ifExists ? 'IF EXISTS ' : '';
|
|
191
|
+
return `DROP TABLE ${ifExistsClause}${this.quoteIdentifier(tableName)}`;
|
|
192
|
+
}
|
|
193
|
+
formatDropIndex(indexName, tableName, ifExists) {
|
|
194
|
+
const ifExistsClause = ifExists ? 'IF EXISTS ' : '';
|
|
195
|
+
return `DROP INDEX ${ifExistsClause}${this.quoteIdentifier(indexName)}`;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
Registry.register('sqlite', (config, schemas) => {
|
|
199
|
+
return new RelatedDatabase(new SQLiteDialect(config), schemas);
|
|
200
|
+
});
|
|
201
|
+
//# sourceMappingURL=sqlite.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqlite.js","sourceRoot":"","sources":["../../src/dialects/sqlite.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAC,MAAM,SAAS,CAAC;AAChC,OAAO,EAAC,QAAQ,EAAC,MAAM,aAAa,CAAC;AAGrC,OAAO,EAAC,eAAe,EAAC,MAAM,0BAA0B,CAAC;AAQzD,MAAM,OAAO,aAAc,SAAQ,OAAoC;IAC7D,EAAE,GAAQ,IAAI,CAAC;IAEvB,YAAY,MAA2B;QACrC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;IAC1B,CAAC;IAED,wBAAwB;IACxB,WAAW;QACT,OAAO,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,OAAO;QACX,IAAI,CAAC;YACH,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,MAAM,CAAC,SAAS,CAAC,CAAC;YACrD,IAAI,CAAC,EAAE,GAAG,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACvD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;YAC1C,MAAM,IAAI,KAAK,CAAC,gBAAgB,KAAK,EAAE,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAED,KAAK,CAAC,UAAU;QACd,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,WAAW;QACf,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,KAAK,CAAU,GAAW,EAAE,MAAc;QAC9C,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,CAAC,GAAQ,EAAE,IAAS,EAAE,EAAE;gBAC/C,IAAI,GAAG,EAAE,CAAC;oBACR,MAAM,CAAC,GAAG,CAAC,CAAC;gBACd,CAAC;qBAAM,CAAC;oBACN,qBAAqB;oBACrB,MAAM,aAAa,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;oBACrD,OAAO,CAAC,aAAkB,CAAC,CAAC;gBAC9B,CAAC;YACH,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,CAAC,GAAQ,EAAE,GAAQ,EAAE,EAAE;gBAC9C,IAAI,GAAG,EAAE,CAAC;oBACR,MAAM,CAAC,GAAG,CAAC,CAAC;gBACd,CAAC;qBAAM,CAAC;oBACN,aAAa;oBACb,MAAM,YAAY,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC;oBACnD,OAAO,CAAC,YAAiB,CAAC,CAAC;gBAC7B,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACK,mBAAmB,CAAC,IAAS;QACnC,IAAI,CAAC,IAAI;YAAE,OAAO,IAAI,CAAC;QAEvB,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC;QACnD,CAAC;aAAM,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YACpC,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACK,cAAc,CAAC,GAAQ;QAC7B,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ;YAAE,OAAO,GAAG,CAAC;QAEhD,MAAM,YAAY,GAAQ,EAAE,CAAC;QAE7B,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YAC/C,YAAY,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QACpD,CAAC;QAED,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;OAEG;IACK,iBAAiB,CAAC,KAAU;QAClC,IAAI,OAAO,KAAK,KAAK,QAAQ;YAAE,OAAO,KAAK,CAAC;QAE5C,mBAAmB;QACnB,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAC9C,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;YACnD,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAEpC,2BAA2B;YAC3B,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;gBACzD,IAAI,CAAC;oBACH,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;gBAC9B,CAAC;gBAAC,MAAM,CAAC;oBACP,oBAAoB;oBACpB,OAAO,QAAQ,CAAC;gBAClB,CAAC;YACH,CAAC;YAED,OAAO,QAAQ,CAAC;QAClB,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,KAAK,CAAC,OAAO;QACX,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;YACZ,MAAM,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC;YACtB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC;QACjB,CAAC;IACH,CAAC;IAED,yBAAyB;IACzB,aAAa,CAAC,IAAY;QACxB,MAAM,OAAO,GAA2B;YACtC,MAAM,EAAE,MAAM;YACd,SAAS,EAAE,SAAS;YACpB,OAAO,EAAE,MAAM;YACf,SAAS,EAAE,SAAS;YACpB,MAAM,EAAE,MAAM;YACd,MAAM,EAAE,MAAM;SACf,CAAC;QACF,OAAO,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,MAAM,CAAC;IAC/C,CAAC;IAED,eAAe,CAAC,UAAkB;QAChC,OAAO,IAAI,UAAU,GAAG,CAAC;IAC3B,CAAC;IAED,uBAAuB,CAAC,KAAa;QACnC,OAAO,GAAG,CAAC;IACb,CAAC;IAED,sBAAsB;QACpB,OAAO,GAAG,CAAC;IACb,CAAC;IAED,aAAa,CAAC,KAAc;QAC1B,OAAO,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;IAC3B,CAAC;IAED,UAAU,CAAC,KAAW;QACpB,OAAO,IAAI,KAAK,CAAC,WAAW,EAAE,GAAG,CAAC;IACpC,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC;IAC1D,CAAC;IAED,YAAY,CAAC,KAAa;QACxB,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,kBAAkB,CAAC,KAAU;QAC3B,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9B,OAAO,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC;QACzC,CAAC;aAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,SAAS,EAAE,CAAC;YACnE,OAAO,KAAK,CAAC,QAAQ,EAAE,CAAC;QAC1B,CAAC;aAAM,IAAI,KAAK,YAAY,IAAI,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC;aAAM,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YAC1B,OAAO,MAAM,CAAC;QAChB,CAAC;aAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,mCAAmC,OAAO,KAAK,EAAE,CAAC,CAAC;QACrE,CAAC;IACH,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,OAAO,SAAS,KAAK,EAAE,CAAC;IAC1B,CAAC;IAED,YAAY,CAAC,MAAc;QACzB,OAAO,UAAU,MAAM,EAAE,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,KAAa,EAAE,MAAc;QAC7C,OAAO,SAAS,KAAK,WAAW,MAAM,EAAE,CAAC;IAC3C,CAAC;IAED,iBAAiB,CAAC,SAAiB,EAAE,OAAiB;QACpD,OAAO,8BAA8B,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;IACjG,CAAC;IAED,sBAAsB,CAAC,KAAa,EAAE,MAAmB;QACvD,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;QACjD,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC7C,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QACzD,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9D,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC;QACrD,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9C,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,KAAK,SAAS;YAC7C,CAAC,CAAC,YAAY,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;YACvD,CAAC,CAAC,EAAE,CAAC;QAEP,OAAO,GAAG,IAAI,IAAI,IAAI,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,QAAQ,GAAG,UAAU,EAAE,CAAC;IAC/E,CAAC;IAED,gBAAgB,CAAC,SAAiB,EAAE,WAAqB;QACvD,OAAO,eAAe,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;IACpF,CAAC;IAED,eAAe,CAAC,SAAiB,EAAE,QAAkB;QACnD,MAAM,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;QACpD,OAAO,cAAc,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,EAAE,CAAC;IAC1E,CAAC;IAED,eAAe,CAAC,SAAiB,EAAE,SAAiB,EAAE,QAAkB;QACtE,MAAM,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;QACpD,OAAO,cAAc,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,EAAE,CAAC;IAC1E,CAAC;CACF;AACD,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,MAA2B,EAAE,OAAkD,EAAE,EAAE;IAC9G,OAAO,IAAI,eAAe,CAAC,IAAI,aAAa,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,CAAC;AACjE,CAAC,CAAC,CAAC"}
|
package/lib/index.d.ts
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export * from './types.js';
|
|
2
|
+
export * from './base/model.js';
|
|
3
|
+
export * from './base/dialect.js';
|
|
4
|
+
export * from './base/database.js';
|
|
5
|
+
export * from './type/related/database.js';
|
|
6
|
+
export * from './type/related/model.js';
|
|
7
|
+
export * from './type/document/database.js';
|
|
8
|
+
export * from './type/document/model.js';
|
|
9
|
+
export * from './type/keyvalue/database.js';
|
|
10
|
+
export * from './type/keyvalue/model.js';
|
|
11
|
+
export * from './registry.js';
|
|
12
|
+
export * from './dialects/memory.js';
|
|
13
|
+
export * from './dialects/mysql.js';
|
|
14
|
+
export * from './dialects/pg.js';
|
|
15
|
+
export * from './dialects/redis.js';
|
|
16
|
+
export * from './dialects/sqlite.js';
|
|
17
|
+
export * from './dialects/mongodb.js';
|
|
18
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,uBAAuB,CAAC"}
|
package/lib/index.js
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export * from './types.js';
|
|
2
|
+
export * from './base/model.js';
|
|
3
|
+
export * from './base/dialect.js';
|
|
4
|
+
export * from './base/database.js';
|
|
5
|
+
export * from './type/related/database.js';
|
|
6
|
+
export * from './type/related/model.js';
|
|
7
|
+
export * from './type/document/database.js';
|
|
8
|
+
export * from './type/document/model.js';
|
|
9
|
+
export * from './type/keyvalue/database.js';
|
|
10
|
+
export * from './type/keyvalue/model.js';
|
|
11
|
+
export * from './registry.js';
|
|
12
|
+
export * from './dialects/memory.js';
|
|
13
|
+
export * from './dialects/mysql.js';
|
|
14
|
+
export * from './dialects/pg.js';
|
|
15
|
+
export * from './dialects/redis.js';
|
|
16
|
+
export * from './dialects/sqlite.js';
|
|
17
|
+
export * from './dialects/mongodb.js';
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,uBAAuB,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Database } from './base/database.js';
|
|
2
|
+
import type { MongoDBDialectConfig } from './dialects/mongodb';
|
|
3
|
+
import { RelatedDatabase } from "./type/related/database";
|
|
4
|
+
import { MemoryConfig } from "./types";
|
|
5
|
+
import { DocumentDatabase } from "./type/document/database";
|
|
6
|
+
import { MySQLDialectConfig } from "./dialects/mysql";
|
|
7
|
+
import { PostgreSQLDialectConfig } from "./dialects/pg";
|
|
8
|
+
import { RedisDialectConfig } from "./dialects/redis";
|
|
9
|
+
import { SQLiteDialectConfig } from "./dialects/sqlite";
|
|
10
|
+
import { KeyValueDatabase } from "./type/keyvalue/database";
|
|
11
|
+
/**
|
|
12
|
+
* 数据库注册表接口
|
|
13
|
+
* 支持模块声明扩展
|
|
14
|
+
*/
|
|
15
|
+
export interface Databases<S extends Record<string, object> = Record<string, object>> {
|
|
16
|
+
memory: RelatedDatabase<MemoryConfig, S>;
|
|
17
|
+
mongodb: DocumentDatabase<MongoDBDialectConfig, S>;
|
|
18
|
+
mysql: RelatedDatabase<MySQLDialectConfig, S>;
|
|
19
|
+
pg: RelatedDatabase<PostgreSQLDialectConfig, S>;
|
|
20
|
+
redis: KeyValueDatabase<RedisDialectConfig, S>;
|
|
21
|
+
sqlite: RelatedDatabase<SQLiteDialectConfig>;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* 数据库注册表命名空间
|
|
25
|
+
*/
|
|
26
|
+
export type Creator<D, S extends Record<string, object>> = (config: D, schemas?: Database.Schemas<S>) => Database<any, S, any>;
|
|
27
|
+
export type Constructor<D, S extends Record<string, object>> = new (config: D, schemas?: Database.Schemas<S>) => Database<any, S, any>;
|
|
28
|
+
export type Factory<D, S extends Record<string, object>> = Creator<any, S> | Constructor<any, S>;
|
|
29
|
+
export declare namespace Registry {
|
|
30
|
+
const factories: Map<any, any>;
|
|
31
|
+
type Config<T extends Database<any, any, any>> = T extends Database<infer D, any, any> ? D : any;
|
|
32
|
+
type DatabaseType = 'related' | 'document' | 'keyvalue';
|
|
33
|
+
function register<D extends string, S extends Record<string, object>>(dialect: D, factory: Factory<any, S>): void;
|
|
34
|
+
function create<D extends string, S extends Record<string, object>>(dialect: D, config: any, schemas?: Database.Schemas<S>): any;
|
|
35
|
+
function isConstructor<D, S extends Record<string, object>>(fn: Factory<D, S>): fn is Constructor<D, S>;
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=registry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../src/registry.ts"],"names":[],"mappings":"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"}
|
package/lib/registry.js
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export var Registry;
|
|
2
|
+
(function (Registry) {
|
|
3
|
+
Registry.factories = new Map();
|
|
4
|
+
function register(dialect, factory) {
|
|
5
|
+
Registry.factories.set(dialect, factory);
|
|
6
|
+
}
|
|
7
|
+
Registry.register = register;
|
|
8
|
+
function create(dialect, config, schemas) {
|
|
9
|
+
const factory = Registry.factories.get(dialect);
|
|
10
|
+
if (!factory) {
|
|
11
|
+
throw new Error(`database dialect ${dialect} not registered`);
|
|
12
|
+
}
|
|
13
|
+
return (isConstructor(factory) ? new factory(config, schemas) : factory(config, schemas));
|
|
14
|
+
}
|
|
15
|
+
Registry.create = create;
|
|
16
|
+
function isConstructor(fn) {
|
|
17
|
+
return fn.prototype && fn.prototype.constructor === fn;
|
|
18
|
+
}
|
|
19
|
+
Registry.isConstructor = isConstructor;
|
|
20
|
+
})(Registry || (Registry = {}));
|
|
21
|
+
//# sourceMappingURL=registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../src/registry.ts"],"names":[],"mappings":"AA+BA,MAAM,KAAW,QAAQ,CA2BxB;AA3BD,WAAiB,QAAQ;IACV,kBAAS,GAAC,IAAI,GAAG,EAAE,CAAC;IAIjC,SAAgB,QAAQ,CACtB,OAAU,EACV,OAAwB;QAExB,SAAA,SAAS,CAAC,GAAG,CAAC,OAAO,EAAE,OAA0B,CAAC,CAAC;IACrD,CAAC;IALe,iBAAQ,WAKvB,CAAA;IAED,SAAgB,MAAM,CACpB,OAAU,EACV,MAAW,EACX,OAA6B;QAE7B,MAAM,OAAO,GAAG,SAAA,SAAS,CAAC,GAAG,CAAC,OAAO,CAAgC,CAAC;QACtE,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,oBAAoB,OAAO,iBAAiB,CAAC,CAAC;QAChE,CAAC;QACD,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAQ,CAAC;IACnG,CAAC;IAVe,eAAM,SAUrB,CAAA;IAED,SAAgB,aAAa,CAAsC,EAAiB;QAClF,OAAO,EAAE,CAAC,SAAS,IAAI,EAAE,CAAC,SAAS,CAAC,WAAW,KAAK,EAAE,CAAC;IACzD,CAAC;IAFe,sBAAa,gBAE5B,CAAA;AACH,CAAC,EA3BgB,QAAQ,KAAR,QAAQ,QA2BxB"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { Database, Dialect } from '../../base';
|
|
2
|
+
import { DocumentModel } from './model.js';
|
|
3
|
+
import { QueryParams, BuildQueryResult, DocumentQueryResult, CreateQueryParams, SelectQueryParams, InsertQueryParams, UpdateQueryParams, DeleteQueryParams, AlterQueryParams, DropTableQueryParams, DropIndexQueryParams } from '../../types.js';
|
|
4
|
+
/**
|
|
5
|
+
* 文档型数据库类
|
|
6
|
+
* 支持集合、文档的文档型数据模型
|
|
7
|
+
*/
|
|
8
|
+
export declare class DocumentDatabase<D = any, S extends Record<string, object> = Record<string, object>> extends Database<D, S, DocumentQueryResult> {
|
|
9
|
+
constructor(dialect: Dialect<D, DocumentQueryResult>, schemas?: Database.Schemas<S>);
|
|
10
|
+
protected initialize(): Promise<void>;
|
|
11
|
+
/**
|
|
12
|
+
* 构建查询(重写基类方法)
|
|
13
|
+
*/
|
|
14
|
+
buildQuery<U extends object = any>(params: QueryParams<U>): BuildQueryResult<DocumentQueryResult>;
|
|
15
|
+
/**
|
|
16
|
+
* 构建创建集合查询
|
|
17
|
+
*/
|
|
18
|
+
protected buildCreateQuery<T extends object>(params: CreateQueryParams<T>): BuildQueryResult<DocumentQueryResult>;
|
|
19
|
+
/**
|
|
20
|
+
* 构建查询文档查询
|
|
21
|
+
*/
|
|
22
|
+
protected buildSelectQuery<T extends object>(params: SelectQueryParams<T>): BuildQueryResult<DocumentQueryResult>;
|
|
23
|
+
/**
|
|
24
|
+
* 构建插入文档查询
|
|
25
|
+
*/
|
|
26
|
+
protected buildInsertQuery<T extends object>(params: InsertQueryParams<T>): BuildQueryResult<DocumentQueryResult>;
|
|
27
|
+
/**
|
|
28
|
+
* 构建更新文档查询
|
|
29
|
+
*/
|
|
30
|
+
protected buildUpdateQuery<T extends object>(params: UpdateQueryParams<T>): BuildQueryResult<DocumentQueryResult>;
|
|
31
|
+
/**
|
|
32
|
+
* 构建删除文档查询
|
|
33
|
+
*/
|
|
34
|
+
protected buildDeleteQuery<T extends object>(params: DeleteQueryParams<T>): BuildQueryResult<DocumentQueryResult>;
|
|
35
|
+
/**
|
|
36
|
+
* 构建修改集合查询
|
|
37
|
+
*/
|
|
38
|
+
protected buildAlterQuery<T extends object>(params: AlterQueryParams<T>): BuildQueryResult<DocumentQueryResult>;
|
|
39
|
+
/**
|
|
40
|
+
* 构建删除集合查询
|
|
41
|
+
*/
|
|
42
|
+
protected buildDropTableQuery<T extends object>(params: DropTableQueryParams<T>): BuildQueryResult<DocumentQueryResult>;
|
|
43
|
+
/**
|
|
44
|
+
* 构建删除索引查询
|
|
45
|
+
*/
|
|
46
|
+
protected buildDropIndexQuery(params: DropIndexQueryParams): BuildQueryResult<DocumentQueryResult>;
|
|
47
|
+
/**
|
|
48
|
+
* 转换条件为文档查询格式
|
|
49
|
+
*/
|
|
50
|
+
private convertConditionToFilter;
|
|
51
|
+
/**
|
|
52
|
+
* 获取模型
|
|
53
|
+
*/
|
|
54
|
+
model<T extends keyof S>(name: T): DocumentModel<S[T], D>;
|
|
55
|
+
/**
|
|
56
|
+
* 获取所有模型名称
|
|
57
|
+
*/
|
|
58
|
+
getModelNames(): string[];
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=database.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"database.d.ts","sourceRoot":"","sources":["../../../src/type/document/database.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EACL,WAAW,EACX,gBAAgB,EAChB,mBAAmB,EACnB,iBAAiB,EACjB,iBAAiB,EACjB,iBAAiB,EACjB,iBAAiB,EACjB,iBAAiB,EACjB,gBAAgB,EAChB,oBAAoB,EACpB,oBAAoB,EACrB,MAAM,gBAAgB,CAAC;AAExB;;;GAGG;AACH,qBAAa,gBAAgB,CAC3B,CAAC,GAAG,GAAG,EACP,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CACzD,SAAQ,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,mBAAmB,CAAC;gBAGzC,OAAO,EAAE,OAAO,CAAC,CAAC,EAAC,mBAAmB,CAAC,EACvC,OAAO,CAAC,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;cAKf,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAK3C;;OAEG;IACH,UAAU,CAAC,CAAC,SAAS,MAAM,GAAG,GAAG,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,mBAAmB,CAAC;IAuBjG;;OAEG;IACH,SAAS,CAAC,gBAAgB,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,mBAAmB,CAAC;IAWjH;;OAEG;IACH,SAAS,CAAC,gBAAgB,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,mBAAmB,CAAC;IAyCjH;;OAEG;IACH,SAAS,CAAC,gBAAgB,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,mBAAmB,CAAC;IAWjH;;OAEG;IACH,SAAS,CAAC,gBAAgB,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,mBAAmB,CAAC;IAiBjH;;OAEG;IACH,SAAS,CAAC,gBAAgB,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,mBAAmB,CAAC;IAiBjH;;OAEG;IACH,SAAS,CAAC,eAAe,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,gBAAgB,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,mBAAmB,CAAC;IAW/G;;OAEG;IACH,SAAS,CAAC,mBAAmB,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,oBAAoB,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,mBAAmB,CAAC;IAWvH;;OAEG;IACH,SAAS,CAAC,mBAAmB,CAAC,MAAM,EAAE,oBAAoB,GAAG,gBAAgB,CAAC,mBAAmB,CAAC;IAWlG;;OAEG;IACH,OAAO,CAAC,wBAAwB;IA2ChC;;OAEG;IACH,KAAK,CAAC,CAAC,SAAS,MAAM,CAAC,EAAE,IAAI,EAAE,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IASzD;;OAEG;IACH,aAAa,IAAI,MAAM,EAAE;CAG1B"}
|
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
import { Database } from '../../base';
|
|
2
|
+
import { DocumentModel } from './model.js';
|
|
3
|
+
/**
|
|
4
|
+
* 文档型数据库类
|
|
5
|
+
* 支持集合、文档的文档型数据模型
|
|
6
|
+
*/
|
|
7
|
+
export class DocumentDatabase extends Database {
|
|
8
|
+
constructor(dialect, schemas) {
|
|
9
|
+
super(dialect, schemas);
|
|
10
|
+
}
|
|
11
|
+
async initialize() {
|
|
12
|
+
// 文档数据库不需要预定义表结构
|
|
13
|
+
// 集合会在第一次使用时自动创建
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* 构建查询(重写基类方法)
|
|
17
|
+
*/
|
|
18
|
+
buildQuery(params) {
|
|
19
|
+
switch (params.type) {
|
|
20
|
+
case 'create':
|
|
21
|
+
return this.buildCreateQuery(params);
|
|
22
|
+
case 'select':
|
|
23
|
+
return this.buildSelectQuery(params);
|
|
24
|
+
case 'insert':
|
|
25
|
+
return this.buildInsertQuery(params);
|
|
26
|
+
case 'update':
|
|
27
|
+
return this.buildUpdateQuery(params);
|
|
28
|
+
case 'delete':
|
|
29
|
+
return this.buildDeleteQuery(params);
|
|
30
|
+
case 'alter':
|
|
31
|
+
return this.buildAlterQuery(params);
|
|
32
|
+
case 'drop_table':
|
|
33
|
+
return this.buildDropTableQuery(params);
|
|
34
|
+
case 'drop_index':
|
|
35
|
+
return this.buildDropIndexQuery(params);
|
|
36
|
+
default:
|
|
37
|
+
throw new Error(`Unsupported query type: ${params.type}`);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* 构建创建集合查询
|
|
42
|
+
*/
|
|
43
|
+
buildCreateQuery(params) {
|
|
44
|
+
return {
|
|
45
|
+
query: {
|
|
46
|
+
collection: params.tableName,
|
|
47
|
+
filter: {},
|
|
48
|
+
projection: {}
|
|
49
|
+
},
|
|
50
|
+
params: []
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* 构建查询文档查询
|
|
55
|
+
*/
|
|
56
|
+
buildSelectQuery(params) {
|
|
57
|
+
const filter = {};
|
|
58
|
+
// 转换条件为文档查询格式
|
|
59
|
+
if (params.conditions) {
|
|
60
|
+
this.convertConditionToFilter(params.conditions, filter);
|
|
61
|
+
}
|
|
62
|
+
const query = {
|
|
63
|
+
collection: params.tableName,
|
|
64
|
+
filter
|
|
65
|
+
};
|
|
66
|
+
if (params.orderings) {
|
|
67
|
+
query.sort = {};
|
|
68
|
+
for (const order of params.orderings) {
|
|
69
|
+
query.sort[order.field] = order.direction === 'ASC' ? 1 : -1;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
if (params.limitCount) {
|
|
73
|
+
query.limit = params.limitCount;
|
|
74
|
+
}
|
|
75
|
+
if (params.offsetCount) {
|
|
76
|
+
query.skip = params.offsetCount;
|
|
77
|
+
}
|
|
78
|
+
if (params.fields && params.fields.length > 0) {
|
|
79
|
+
query.projection = {};
|
|
80
|
+
for (const field of params.fields) {
|
|
81
|
+
query.projection[field] = 1;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return {
|
|
85
|
+
query,
|
|
86
|
+
params: []
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* 构建插入文档查询
|
|
91
|
+
*/
|
|
92
|
+
buildInsertQuery(params) {
|
|
93
|
+
return {
|
|
94
|
+
query: {
|
|
95
|
+
collection: params.tableName,
|
|
96
|
+
filter: {},
|
|
97
|
+
projection: {}
|
|
98
|
+
},
|
|
99
|
+
params: [params.data]
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* 构建更新文档查询
|
|
104
|
+
*/
|
|
105
|
+
buildUpdateQuery(params) {
|
|
106
|
+
const filter = {};
|
|
107
|
+
if (params.conditions) {
|
|
108
|
+
this.convertConditionToFilter(params.conditions, filter);
|
|
109
|
+
}
|
|
110
|
+
return {
|
|
111
|
+
query: {
|
|
112
|
+
collection: params.tableName,
|
|
113
|
+
filter,
|
|
114
|
+
projection: {}
|
|
115
|
+
},
|
|
116
|
+
params: [params.update]
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* 构建删除文档查询
|
|
121
|
+
*/
|
|
122
|
+
buildDeleteQuery(params) {
|
|
123
|
+
const filter = {};
|
|
124
|
+
if (params.conditions) {
|
|
125
|
+
this.convertConditionToFilter(params.conditions, filter);
|
|
126
|
+
}
|
|
127
|
+
return {
|
|
128
|
+
query: {
|
|
129
|
+
collection: params.tableName,
|
|
130
|
+
filter,
|
|
131
|
+
projection: {}
|
|
132
|
+
},
|
|
133
|
+
params: []
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* 构建修改集合查询
|
|
138
|
+
*/
|
|
139
|
+
buildAlterQuery(params) {
|
|
140
|
+
return {
|
|
141
|
+
query: {
|
|
142
|
+
collection: params.tableName,
|
|
143
|
+
filter: {},
|
|
144
|
+
projection: {}
|
|
145
|
+
},
|
|
146
|
+
params: [params.alterations]
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* 构建删除集合查询
|
|
151
|
+
*/
|
|
152
|
+
buildDropTableQuery(params) {
|
|
153
|
+
return {
|
|
154
|
+
query: {
|
|
155
|
+
collection: params.tableName,
|
|
156
|
+
filter: {},
|
|
157
|
+
projection: {}
|
|
158
|
+
},
|
|
159
|
+
params: []
|
|
160
|
+
};
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* 构建删除索引查询
|
|
164
|
+
*/
|
|
165
|
+
buildDropIndexQuery(params) {
|
|
166
|
+
return {
|
|
167
|
+
query: {
|
|
168
|
+
collection: params.tableName,
|
|
169
|
+
filter: {},
|
|
170
|
+
projection: {}
|
|
171
|
+
},
|
|
172
|
+
params: [params.indexName]
|
|
173
|
+
};
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* 转换条件为文档查询格式
|
|
177
|
+
*/
|
|
178
|
+
convertConditionToFilter(condition, filter) {
|
|
179
|
+
if (typeof condition !== 'object' || condition === null) {
|
|
180
|
+
return;
|
|
181
|
+
}
|
|
182
|
+
for (const [key, value] of Object.entries(condition)) {
|
|
183
|
+
if (key.startsWith('$')) {
|
|
184
|
+
// 逻辑操作符
|
|
185
|
+
if (key === '$and' && Array.isArray(value)) {
|
|
186
|
+
filter.$and = value.map(cond => {
|
|
187
|
+
const subFilter = {};
|
|
188
|
+
this.convertConditionToFilter(cond, subFilter);
|
|
189
|
+
return subFilter;
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
else if (key === '$or' && Array.isArray(value)) {
|
|
193
|
+
filter.$or = value.map(cond => {
|
|
194
|
+
const subFilter = {};
|
|
195
|
+
this.convertConditionToFilter(cond, subFilter);
|
|
196
|
+
return subFilter;
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
else if (key === '$not') {
|
|
200
|
+
const subFilter = {};
|
|
201
|
+
this.convertConditionToFilter(value, subFilter);
|
|
202
|
+
filter.$not = subFilter;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
else if (typeof value === 'object' && value !== null) {
|
|
206
|
+
// 比较操作符
|
|
207
|
+
const fieldFilter = {};
|
|
208
|
+
for (const [op, opValue] of Object.entries(value)) {
|
|
209
|
+
if (op.startsWith('$')) {
|
|
210
|
+
fieldFilter[op] = opValue;
|
|
211
|
+
}
|
|
212
|
+
else {
|
|
213
|
+
fieldFilter.$eq = value;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
filter[key] = Object.keys(fieldFilter).length > 0 ? fieldFilter : value;
|
|
217
|
+
}
|
|
218
|
+
else {
|
|
219
|
+
// 简单相等
|
|
220
|
+
filter[key] = { $eq: value };
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
/**
|
|
225
|
+
* 获取模型
|
|
226
|
+
*/
|
|
227
|
+
model(name) {
|
|
228
|
+
let model = this.models.get(name);
|
|
229
|
+
if (!model) {
|
|
230
|
+
model = new DocumentModel(this, name);
|
|
231
|
+
this.models.set(name, model);
|
|
232
|
+
}
|
|
233
|
+
return model;
|
|
234
|
+
}
|
|
235
|
+
/**
|
|
236
|
+
* 获取所有模型名称
|
|
237
|
+
*/
|
|
238
|
+
getModelNames() {
|
|
239
|
+
return Object.keys(this.schemas || {});
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
//# sourceMappingURL=database.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"database.js","sourceRoot":"","sources":["../../../src/type/document/database.ts"],"names":[],"mappings":"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"}
|