@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.
Files changed (109) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +93 -0
  3. package/lib/base/database.d.ts +71 -0
  4. package/lib/base/database.d.ts.map +1 -0
  5. package/lib/base/database.js +101 -0
  6. package/lib/base/database.js.map +1 -0
  7. package/lib/base/dialect.d.ts +34 -0
  8. package/lib/base/dialect.d.ts.map +1 -0
  9. package/lib/base/dialect.js +21 -0
  10. package/lib/base/dialect.js.map +1 -0
  11. package/lib/base/index.d.ts +6 -0
  12. package/lib/base/index.d.ts.map +1 -0
  13. package/lib/base/index.js +6 -0
  14. package/lib/base/index.js.map +1 -0
  15. package/lib/base/model.d.ts +53 -0
  16. package/lib/base/model.d.ts.map +1 -0
  17. package/lib/base/model.js +65 -0
  18. package/lib/base/model.js.map +1 -0
  19. package/lib/base/query-classes.d.ts +68 -0
  20. package/lib/base/query-classes.d.ts.map +1 -0
  21. package/lib/base/query-classes.js +178 -0
  22. package/lib/base/query-classes.js.map +1 -0
  23. package/lib/base/thenable.d.ts +15 -0
  24. package/lib/base/thenable.d.ts.map +1 -0
  25. package/lib/base/thenable.js +33 -0
  26. package/lib/base/thenable.js.map +1 -0
  27. package/lib/dialects/memory.d.ts +52 -0
  28. package/lib/dialects/memory.d.ts.map +1 -0
  29. package/lib/dialects/memory.js +772 -0
  30. package/lib/dialects/memory.js.map +1 -0
  31. package/lib/dialects/mongodb.d.ts +85 -0
  32. package/lib/dialects/mongodb.d.ts.map +1 -0
  33. package/lib/dialects/mongodb.js +461 -0
  34. package/lib/dialects/mongodb.js.map +1 -0
  35. package/lib/dialects/mysql.d.ts +33 -0
  36. package/lib/dialects/mysql.d.ts.map +1 -0
  37. package/lib/dialects/mysql.js +132 -0
  38. package/lib/dialects/mysql.js.map +1 -0
  39. package/lib/dialects/pg.d.ts +33 -0
  40. package/lib/dialects/pg.d.ts.map +1 -0
  41. package/lib/dialects/pg.js +132 -0
  42. package/lib/dialects/pg.js.map +1 -0
  43. package/lib/dialects/redis.d.ts +87 -0
  44. package/lib/dialects/redis.d.ts.map +1 -0
  45. package/lib/dialects/redis.js +500 -0
  46. package/lib/dialects/redis.js.map +1 -0
  47. package/lib/dialects/sqlite.d.ts +46 -0
  48. package/lib/dialects/sqlite.d.ts.map +1 -0
  49. package/lib/dialects/sqlite.js +201 -0
  50. package/lib/dialects/sqlite.js.map +1 -0
  51. package/lib/index.d.ts +18 -0
  52. package/lib/index.d.ts.map +1 -0
  53. package/lib/index.js +18 -0
  54. package/lib/index.js.map +1 -0
  55. package/lib/registry.d.ts +37 -0
  56. package/lib/registry.d.ts.map +1 -0
  57. package/lib/registry.js +21 -0
  58. package/lib/registry.js.map +1 -0
  59. package/lib/type/document/database.d.ts +60 -0
  60. package/lib/type/document/database.d.ts.map +1 -0
  61. package/lib/type/document/database.js +242 -0
  62. package/lib/type/document/database.js.map +1 -0
  63. package/lib/type/document/model.d.ts +42 -0
  64. package/lib/type/document/model.d.ts.map +1 -0
  65. package/lib/type/document/model.js +65 -0
  66. package/lib/type/document/model.js.map +1 -0
  67. package/lib/type/keyvalue/database.d.ts +64 -0
  68. package/lib/type/keyvalue/database.d.ts.map +1 -0
  69. package/lib/type/keyvalue/database.js +214 -0
  70. package/lib/type/keyvalue/database.js.map +1 -0
  71. package/lib/type/keyvalue/model.d.ts +107 -0
  72. package/lib/type/keyvalue/model.d.ts.map +1 -0
  73. package/lib/type/keyvalue/model.js +261 -0
  74. package/lib/type/keyvalue/model.js.map +1 -0
  75. package/lib/type/related/database.d.ts +32 -0
  76. package/lib/type/related/database.d.ts.map +1 -0
  77. package/lib/type/related/database.js +334 -0
  78. package/lib/type/related/database.js.map +1 -0
  79. package/lib/type/related/model.d.ts +43 -0
  80. package/lib/type/related/model.d.ts.map +1 -0
  81. package/lib/type/related/model.js +108 -0
  82. package/lib/type/related/model.js.map +1 -0
  83. package/lib/types.d.ts +251 -0
  84. package/lib/types.d.ts.map +1 -0
  85. package/lib/types.js +28 -0
  86. package/lib/types.js.map +1 -0
  87. package/package.json +54 -0
  88. package/src/base/database.ts +128 -0
  89. package/src/base/dialect.ts +76 -0
  90. package/src/base/index.ts +5 -0
  91. package/src/base/model.ts +89 -0
  92. package/src/base/query-classes.ts +217 -0
  93. package/src/base/thenable.ts +54 -0
  94. package/src/dialects/memory.ts +880 -0
  95. package/src/dialects/mongodb.ts +533 -0
  96. package/src/dialects/mysql.ts +157 -0
  97. package/src/dialects/pg.ts +157 -0
  98. package/src/dialects/redis.ts +598 -0
  99. package/src/dialects/sqlite.ts +233 -0
  100. package/src/index.ts +20 -0
  101. package/src/registry.ts +59 -0
  102. package/src/type/document/database.ts +283 -0
  103. package/src/type/document/model.ts +86 -0
  104. package/src/type/keyvalue/database.ts +261 -0
  105. package/src/type/keyvalue/model.ts +339 -0
  106. package/src/type/related/database.ts +392 -0
  107. package/src/type/related/model.ts +117 -0
  108. package/src/types.ts +403 -0
  109. 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":"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"}
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
@@ -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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"}
@@ -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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"}