@ignisia/sql 0.2.2 → 0.4.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/README.md +1 -1
- package/dist/cjs/column/constants.d.cts +58 -5
- package/dist/cjs/column/constants.js +79 -22
- package/dist/cjs/column/index.d.cts +1 -0
- package/dist/cjs/column/index.js +31 -18
- package/dist/cjs/column/utils.d.cts +133 -0
- package/dist/cjs/column/utils.js +34 -0
- package/dist/cjs/database/alter.d.cts +3 -2
- package/dist/cjs/database/alter.js +15 -15
- package/dist/cjs/database/column.d.cts +3 -2
- package/dist/cjs/database/column.js +9 -7
- package/dist/cjs/database/contract.d.cts +3 -2
- package/dist/cjs/database/index.d.cts +3 -2
- package/dist/cjs/database/index.js +15 -2
- package/dist/cjs/database/table.d.cts +3 -2
- package/dist/cjs/database/table.js +12 -4
- package/dist/cjs/database/types.d.cts +2 -1
- package/dist/cjs/database/wrapper.d.cts +17 -21
- package/dist/cjs/database/wrapper.js +28 -52
- package/dist/cjs/index-CHxuUiO4.d.cts +472 -0
- package/dist/cjs/{index---zaMa69.d.cts → index-CZhrzE5r.d.cts} +5 -3
- package/dist/cjs/index.d.cts +3 -2
- package/dist/cjs/migration/index.d.cts +3 -2
- package/dist/cjs/migration/runner.js +1 -1
- package/dist/cjs/migration/type.d.cts +3 -2
- package/dist/cjs/query/builder.d.cts +3 -2
- package/dist/cjs/query/builder.js +1 -1
- package/dist/cjs/query/condition/common.d.cts +41 -0
- package/dist/cjs/query/condition/common.js +62 -0
- package/dist/cjs/query/condition/core.d.cts +8 -0
- package/dist/cjs/query/condition/core.js +57 -0
- package/dist/cjs/query/condition/index.d.cts +10 -0
- package/dist/cjs/query/condition/index.js +33 -0
- package/dist/cjs/query/condition/not.d.cts +34 -0
- package/dist/cjs/query/condition/not.js +51 -0
- package/dist/cjs/query/condition/raw.d.cts +8 -0
- package/dist/cjs/query/condition/raw.js +54 -0
- package/dist/cjs/query/constants.d.cts +27 -1
- package/dist/cjs/query/constants.js +28 -2
- package/dist/cjs/query/contract.d.cts +4 -3
- package/dist/cjs/query/explain.d.cts +12 -0
- package/dist/cjs/query/explain.js +65 -0
- package/dist/cjs/query/helper.d.cts +3 -2
- package/dist/cjs/query/helper.js +1 -1
- package/dist/cjs/query/index.d.cts +3 -2
- package/dist/cjs/query/index.js +69 -65
- package/dist/cjs/query/join.d.cts +18 -5
- package/dist/cjs/query/join.js +38 -9
- package/dist/cjs/query/sql.d.cts +9 -6
- package/dist/cjs/query/sql.js +80 -21
- package/dist/cjs/query/types.d.cts +2 -1
- package/dist/cjs/query/utilities.d.cts +7 -3
- package/dist/cjs/query/utilities.js +86 -5
- package/dist/cjs/table/constants.d.cts +1 -0
- package/dist/cjs/table/constants.js +1 -0
- package/dist/cjs/table/index.d.cts +3 -2
- package/dist/cjs/table/index.js +29 -9
- package/dist/cjs/table/types.d.cts +3 -2
- package/dist/cjs/table/utilities.d.cts +2 -1
- package/dist/cjs/types.d.cts +5 -1
- package/dist/cjs/utilities.d.cts +2 -1
- package/dist/cjs/utilities.js +22 -0
- package/dist/esm/column/constants.d.ts +58 -5
- package/dist/esm/column/constants.js +78 -23
- package/dist/esm/column/index.d.ts +1 -0
- package/dist/esm/column/index.js +31 -18
- package/dist/esm/column/utils.d.ts +133 -0
- package/dist/esm/column/utils.js +32 -0
- package/dist/esm/database/alter.d.ts +3 -2
- package/dist/esm/database/alter.js +15 -15
- package/dist/esm/database/column.d.ts +3 -2
- package/dist/esm/database/column.js +9 -7
- package/dist/esm/database/contract.d.ts +3 -2
- package/dist/esm/database/index.d.ts +3 -2
- package/dist/esm/database/index.js +17 -4
- package/dist/esm/database/table.d.ts +3 -2
- package/dist/esm/database/table.js +12 -4
- package/dist/esm/database/types.d.ts +2 -1
- package/dist/esm/database/wrapper.d.ts +17 -21
- package/dist/esm/database/wrapper.js +27 -53
- package/dist/esm/index-CjurLJdK.d.ts +472 -0
- package/dist/esm/{index-DFrpzXEn.d.ts → index-DgOs61lH.d.ts} +5 -3
- package/dist/esm/index.d.ts +3 -2
- package/dist/esm/migration/index.d.ts +3 -2
- package/dist/esm/migration/runner.js +1 -1
- package/dist/esm/migration/type.d.ts +3 -2
- package/dist/esm/query/builder.d.ts +3 -2
- package/dist/esm/query/builder.js +1 -1
- package/dist/esm/query/condition/common.d.ts +41 -0
- package/dist/esm/query/condition/common.js +56 -0
- package/dist/esm/query/condition/core.d.ts +8 -0
- package/dist/esm/query/condition/core.js +55 -0
- package/dist/esm/query/condition/index.d.ts +10 -0
- package/dist/esm/query/condition/index.js +4 -0
- package/dist/esm/query/condition/not.d.ts +34 -0
- package/dist/esm/query/condition/not.js +46 -0
- package/dist/esm/query/condition/raw.d.ts +8 -0
- package/dist/esm/query/condition/raw.js +50 -0
- package/dist/esm/query/constants.d.ts +27 -1
- package/dist/esm/query/constants.js +27 -3
- package/dist/esm/query/contract.d.ts +4 -3
- package/dist/esm/query/explain.d.ts +12 -0
- package/dist/esm/query/explain.js +64 -0
- package/dist/esm/query/helper.d.ts +3 -2
- package/dist/esm/query/helper.js +2 -2
- package/dist/esm/query/index.d.ts +3 -2
- package/dist/esm/query/index.js +72 -68
- package/dist/esm/query/join.d.ts +18 -5
- package/dist/esm/query/join.js +37 -9
- package/dist/esm/query/sql.d.ts +9 -6
- package/dist/esm/query/sql.js +80 -23
- package/dist/esm/query/types.d.ts +2 -1
- package/dist/esm/query/utilities.d.ts +7 -3
- package/dist/esm/query/utilities.js +86 -6
- package/dist/esm/table/constants.d.ts +1 -0
- package/dist/esm/table/constants.js +1 -0
- package/dist/esm/table/index.d.ts +3 -2
- package/dist/esm/table/index.js +29 -9
- package/dist/esm/table/types.d.ts +3 -2
- package/dist/esm/table/utilities.d.ts +2 -1
- package/dist/esm/types.d.ts +5 -1
- package/dist/esm/utilities.d.ts +2 -1
- package/dist/esm/utilities.js +22 -1
- package/package.json +8 -2
- package/dist/cjs/index-CwiFQh0I.d.cts +0 -358
- package/dist/cjs/query/condition.d.cts +0 -7
- package/dist/cjs/query/condition.js +0 -106
- package/dist/esm/index-FMT0YEO7.d.ts +0 -358
- package/dist/esm/query/condition.d.ts +0 -7
- package/dist/esm/query/condition.js +0 -98
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
var constants = require('../table/constants');
|
|
4
4
|
|
|
5
5
|
async function addColumn(tableName, columnName, column) {
|
|
6
|
-
await this.client.exec(
|
|
7
|
-
`ALTER TABLE ${tableName} ADD COLUMN ${columnName} ${column.toString()};`
|
|
8
|
-
);
|
|
6
|
+
await this.client.exec({
|
|
7
|
+
sql: `ALTER TABLE ${tableName} ADD COLUMN ${columnName} ${column.toString()};`
|
|
8
|
+
});
|
|
9
9
|
if (!this.tables[tableName]) return this;
|
|
10
10
|
this.tables[tableName].columns[columnName] = column;
|
|
11
11
|
return this;
|
|
@@ -14,9 +14,9 @@ async function renameColumn(tableName, oldName, newName) {
|
|
|
14
14
|
if (this.dialect === constants.Dialect.SQLITE) {
|
|
15
15
|
throw new Error("SQLite does not support RENAME COLUMN natively.");
|
|
16
16
|
}
|
|
17
|
-
await this.client.exec(
|
|
18
|
-
`ALTER TABLE ${tableName} RENAME COLUMN ${oldName} TO ${newName};`
|
|
19
|
-
);
|
|
17
|
+
await this.client.exec({
|
|
18
|
+
sql: `ALTER TABLE ${tableName} RENAME COLUMN ${oldName} TO ${newName};`
|
|
19
|
+
});
|
|
20
20
|
if (!this.tables[tableName]) return this;
|
|
21
21
|
this.tables[tableName].columns[newName] = this.tables[tableName].columns[oldName];
|
|
22
22
|
delete this.tables[tableName].columns[oldName];
|
|
@@ -26,7 +26,9 @@ async function dropColumn(tableName, columnName) {
|
|
|
26
26
|
if (this.dialect === constants.Dialect.SQLITE) {
|
|
27
27
|
throw new Error("SQLite does not support DROP COLUMN natively.");
|
|
28
28
|
}
|
|
29
|
-
await this.client.exec(
|
|
29
|
+
await this.client.exec({
|
|
30
|
+
sql: `ALTER TABLE ${tableName} DROP COLUMN ${columnName};`
|
|
31
|
+
});
|
|
30
32
|
if (!this.tables[tableName]) return this;
|
|
31
33
|
delete this.tables[tableName].columns[columnName];
|
|
32
34
|
return this;
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
export { C as ColumnAlterationContract, T as TableAlterationContract } from '../index
|
|
1
|
+
export { C as ColumnAlterationContract, T as TableAlterationContract } from '../index-CZhrzE5r.cjs';
|
|
2
2
|
import '../column/index.cjs';
|
|
3
3
|
import '../column/constants.cjs';
|
|
4
|
-
import '../index-
|
|
4
|
+
import '../index-CHxuUiO4.cjs';
|
|
5
5
|
import '../table/constants.cjs';
|
|
6
|
+
import 'bun';
|
|
6
7
|
import '../query/constants.cjs';
|
|
7
8
|
import '../column/types.cjs';
|
|
8
9
|
import '../types.cjs';
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
+
import 'bun';
|
|
1
2
|
import '../column/index.cjs';
|
|
2
|
-
import '../index-
|
|
3
|
+
import '../index-CHxuUiO4.cjs';
|
|
3
4
|
import '../query/constants.cjs';
|
|
4
5
|
import '../table/constants.cjs';
|
|
5
|
-
export { D as Database } from '../index
|
|
6
|
+
export { D as Database } from '../index-CZhrzE5r.cjs';
|
|
6
7
|
import '../column/constants.cjs';
|
|
7
8
|
import '../column/types.cjs';
|
|
8
9
|
import '../types.cjs';
|
|
@@ -32,10 +32,11 @@ class Database {
|
|
|
32
32
|
dialect: options.dialect,
|
|
33
33
|
config: options.config
|
|
34
34
|
};
|
|
35
|
-
this.client =
|
|
35
|
+
this.client = this.createClient(options);
|
|
36
36
|
if (options.tables) {
|
|
37
37
|
for (const tableName in options.tables) {
|
|
38
38
|
options.tables[tableName].client = this.client;
|
|
39
|
+
options.tables[tableName].setDialect(this.dialect);
|
|
39
40
|
}
|
|
40
41
|
}
|
|
41
42
|
this.createTable = table.createTable.bind(this);
|
|
@@ -53,13 +54,25 @@ class Database {
|
|
|
53
54
|
this.dropColumnDefault = alter.dropColumnDefault.bind(
|
|
54
55
|
this
|
|
55
56
|
);
|
|
56
|
-
this.setColumnNotNull = alter.
|
|
57
|
+
this.setColumnNotNull = alter.setColumnNotNull.bind(
|
|
57
58
|
this
|
|
58
59
|
);
|
|
59
60
|
this.dropColumnNotNull = alter.dropColumnNotNull.bind(
|
|
60
61
|
this
|
|
61
62
|
);
|
|
62
63
|
}
|
|
64
|
+
createClient(options) {
|
|
65
|
+
switch (options.dialect) {
|
|
66
|
+
case constants.Dialect.SQLITE:
|
|
67
|
+
return new wrapper.DatabaseSqlite(options.config);
|
|
68
|
+
case constants.Dialect.POSTGRES:
|
|
69
|
+
return new wrapper.DatabasePsql(options.config);
|
|
70
|
+
case constants.Dialect.MYSQL:
|
|
71
|
+
return new wrapper.DatabaseMysql(options.config);
|
|
72
|
+
default:
|
|
73
|
+
throw new Error(`Dialect ${options.dialect} is not supported`);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
63
76
|
table(tableName) {
|
|
64
77
|
if (!this.tables[tableName]) {
|
|
65
78
|
throw new Error(`Table ${tableName} does not exist`);
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import { D as Database } from '../index
|
|
1
|
+
import { D as Database } from '../index-CZhrzE5r.cjs';
|
|
2
2
|
import { Column } from '../column/index.cjs';
|
|
3
|
-
import { T as Table, D as DatabaseDefinition,
|
|
3
|
+
import { T as Table, D as DatabaseDefinition, f as TimestampOptions, M as MergeTimestampParanoid } from '../index-CHxuUiO4.cjs';
|
|
4
4
|
import { Dialect } from '../table/constants.cjs';
|
|
5
|
+
import 'bun';
|
|
5
6
|
import '../query/constants.cjs';
|
|
6
7
|
import '../column/constants.cjs';
|
|
7
8
|
import '../column/types.cjs';
|
|
@@ -17,21 +17,29 @@ async function createTable(tableName, columns, options) {
|
|
|
17
17
|
while (this.client.status === "connecting") {
|
|
18
18
|
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
19
19
|
}
|
|
20
|
-
await table$1.create(
|
|
20
|
+
await table$1.create({
|
|
21
|
+
db: this.client
|
|
22
|
+
});
|
|
21
23
|
return this;
|
|
22
24
|
}
|
|
23
25
|
async function renameTable(oldName, newName) {
|
|
24
|
-
await this.client.exec(
|
|
26
|
+
await this.client.exec({
|
|
27
|
+
sql: `ALTER TABLE ${oldName} RENAME TO ${newName};`
|
|
28
|
+
});
|
|
25
29
|
this.tables[newName] = this.tables[oldName];
|
|
26
30
|
delete this.tables[oldName];
|
|
27
31
|
return this;
|
|
28
32
|
}
|
|
29
33
|
async function dropTable(tableName) {
|
|
30
34
|
if (!this.tables[tableName]) {
|
|
31
|
-
await this.client.exec(
|
|
35
|
+
await this.client.exec({
|
|
36
|
+
sql: `DROP TABLE IF EXISTS ${tableName};`
|
|
37
|
+
});
|
|
32
38
|
return this;
|
|
33
39
|
}
|
|
34
|
-
await this.tables[tableName].drop(
|
|
40
|
+
await this.tables[tableName].drop({
|
|
41
|
+
db: this.client
|
|
42
|
+
});
|
|
35
43
|
delete this.tables[tableName];
|
|
36
44
|
return this;
|
|
37
45
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import 'bun';
|
|
1
2
|
import '../column/index.cjs';
|
|
2
|
-
export { D as DatabaseDefinition,
|
|
3
|
+
export { D as DatabaseDefinition, g as DatabaseDialect, h as DatabaseExecOptions, q as DatabaseOptions, i as MysqlConfig, P as PostgresConfig, J as SqlConfig, S as SqlConfigMapping, j as SqliteConfig } from '../index-CHxuUiO4.cjs';
|
|
3
4
|
import '../table/constants.cjs';
|
|
4
5
|
import '../column/constants.cjs';
|
|
5
6
|
import '../column/types.cjs';
|
|
@@ -1,36 +1,32 @@
|
|
|
1
|
-
import { SQL } from 'bun';
|
|
2
|
-
import { Database } from 'bun:sqlite';
|
|
1
|
+
import { SQL, TransactionSQL } from 'bun';
|
|
3
2
|
import { Dialect } from '../table/constants.cjs';
|
|
4
|
-
import {
|
|
3
|
+
import { S as SqlConfigMapping, g as DatabaseDialect, h as DatabaseExecOptions, P as PostgresConfig, i as MysqlConfig, j as SqliteConfig } from '../index-CHxuUiO4.cjs';
|
|
5
4
|
import '../column/index.cjs';
|
|
6
5
|
import '../column/constants.cjs';
|
|
7
6
|
import '../column/types.cjs';
|
|
8
7
|
import '../types.cjs';
|
|
9
8
|
import '../query/constants.cjs';
|
|
10
9
|
|
|
11
|
-
declare class
|
|
12
|
-
readonly dialect:
|
|
13
|
-
readonly options:
|
|
10
|
+
declare class BaseSql<DbDialect extends Dialect, Options extends SqlConfigMapping[DbDialect]> implements DatabaseDialect {
|
|
11
|
+
readonly dialect: Dialect;
|
|
12
|
+
readonly options: Options;
|
|
14
13
|
client: SQL;
|
|
15
14
|
status: 'connecting' | 'connected' | 'disconnected';
|
|
16
|
-
constructor(options:
|
|
15
|
+
constructor(dialect: Dialect, options: Options);
|
|
17
16
|
connect(): Promise<this>;
|
|
18
17
|
disconnect(): Promise<this>;
|
|
19
|
-
exec<T>(
|
|
20
|
-
|
|
21
|
-
|
|
18
|
+
exec<T>(options: DatabaseExecOptions): Promise<T>;
|
|
19
|
+
transaction<T, U extends (tx: TransactionSQL) => Promise<T>>(fn: U): Promise<T>;
|
|
20
|
+
distributed<T extends string, U, V extends (tx: TransactionSQL) => Promise<U>>(name: T, fn: V): Promise<U>;
|
|
22
21
|
}
|
|
23
|
-
declare class
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
22
|
+
declare class DatabasePsql extends BaseSql<typeof Dialect.POSTGRES, PostgresConfig> {
|
|
23
|
+
constructor(options: PostgresConfig);
|
|
24
|
+
}
|
|
25
|
+
declare class DatabaseMysql extends BaseSql<typeof Dialect.MYSQL, MysqlConfig> {
|
|
26
|
+
constructor(options: MysqlConfig);
|
|
27
|
+
}
|
|
28
|
+
declare class DatabaseSqlite extends BaseSql<typeof Dialect.SQLITE, SqliteConfig> {
|
|
28
29
|
constructor(options: SqliteConfig);
|
|
29
|
-
connect(): Promise<this>;
|
|
30
|
-
disconnect(): Promise<this>;
|
|
31
|
-
exec<T>(sql: string): Promise<T>;
|
|
32
|
-
exec<T>(sql: string, params: any): Promise<T>;
|
|
33
|
-
transaction<T, U extends () => Promise<T>>(fn: U): Promise<T>;
|
|
34
30
|
}
|
|
35
31
|
|
|
36
|
-
export { DatabasePsql, DatabaseSqlite };
|
|
32
|
+
export { BaseSql, DatabaseMysql, DatabasePsql, DatabaseSqlite };
|
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var bun = require('bun');
|
|
4
|
-
var bun_sqlite = require('bun:sqlite');
|
|
5
4
|
var constants = require('../table/constants');
|
|
6
5
|
|
|
7
|
-
class
|
|
6
|
+
class BaseSql {
|
|
8
7
|
dialect;
|
|
9
8
|
options;
|
|
10
9
|
client;
|
|
11
10
|
status;
|
|
12
|
-
constructor(options) {
|
|
13
|
-
this.dialect =
|
|
11
|
+
constructor(dialect, options) {
|
|
12
|
+
this.dialect = dialect;
|
|
14
13
|
this.options = options;
|
|
15
14
|
this.status = "connecting";
|
|
16
15
|
this.client = new bun.SQL({
|
|
17
16
|
...options,
|
|
17
|
+
adapter: dialect,
|
|
18
18
|
onconnect: () => {
|
|
19
19
|
this.status = "connected";
|
|
20
20
|
},
|
|
@@ -32,64 +32,40 @@ class DatabasePsql {
|
|
|
32
32
|
await this.client.close();
|
|
33
33
|
return this;
|
|
34
34
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
if (!
|
|
38
|
-
|
|
35
|
+
async exec(options) {
|
|
36
|
+
const client = options.tx || this.client;
|
|
37
|
+
if (!client) {
|
|
38
|
+
throw new Error("Database not connected");
|
|
39
|
+
}
|
|
40
|
+
if (!options.params) {
|
|
41
|
+
return client.unsafe(options.sql);
|
|
39
42
|
}
|
|
40
|
-
return
|
|
43
|
+
return client.unsafe(options.sql, options.params);
|
|
41
44
|
}
|
|
42
45
|
async transaction(fn) {
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
return result;
|
|
48
|
-
} catch (err) {
|
|
49
|
-
await this.exec("ROLLBACK");
|
|
50
|
-
throw err;
|
|
51
|
-
}
|
|
46
|
+
return this.client.transaction(fn);
|
|
47
|
+
}
|
|
48
|
+
async distributed(name, fn) {
|
|
49
|
+
return this.client.distributed(name, fn);
|
|
52
50
|
}
|
|
53
51
|
}
|
|
54
|
-
class
|
|
55
|
-
dialect;
|
|
56
|
-
options;
|
|
57
|
-
client;
|
|
58
|
-
status;
|
|
52
|
+
class DatabasePsql extends BaseSql {
|
|
59
53
|
constructor(options) {
|
|
60
|
-
|
|
61
|
-
this.options = options;
|
|
62
|
-
this.status = "connecting";
|
|
63
|
-
this.client = new bun_sqlite.Database(options.filename);
|
|
64
|
-
this.status = "connected";
|
|
65
|
-
}
|
|
66
|
-
async connect() {
|
|
67
|
-
this.client = new bun_sqlite.Database(this.options.filename);
|
|
68
|
-
this.status = "connected";
|
|
69
|
-
return this;
|
|
70
|
-
}
|
|
71
|
-
async disconnect() {
|
|
72
|
-
this.client.close();
|
|
73
|
-
this.status = "disconnected";
|
|
74
|
-
return this;
|
|
54
|
+
super(constants.Dialect.POSTGRES, options);
|
|
75
55
|
}
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
56
|
+
}
|
|
57
|
+
class DatabaseMysql extends BaseSql {
|
|
58
|
+
constructor(options) {
|
|
59
|
+
super(constants.Dialect.MYSQL, options);
|
|
80
60
|
}
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
await this.exec("COMMIT");
|
|
86
|
-
return result;
|
|
87
|
-
} catch (err) {
|
|
88
|
-
await this.exec("ROLLBACK");
|
|
89
|
-
throw err;
|
|
90
|
-
}
|
|
61
|
+
}
|
|
62
|
+
class DatabaseSqlite extends BaseSql {
|
|
63
|
+
constructor(options) {
|
|
64
|
+
super(constants.Dialect.SQLITE, options);
|
|
91
65
|
}
|
|
92
66
|
}
|
|
93
67
|
|
|
68
|
+
exports.BaseSql = BaseSql;
|
|
69
|
+
exports.DatabaseMysql = DatabaseMysql;
|
|
94
70
|
exports.DatabasePsql = DatabasePsql;
|
|
95
71
|
exports.DatabaseSqlite = DatabaseSqlite;
|