@taylordb/query-builder 0.9.0 → 0.9.1
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 +42 -0
- package/dist/cjs/aggregation-query-builder.d.ts +92 -0
- package/dist/cjs/aggregation-query-builder.js +92 -0
- package/dist/cjs/aggregation-query-builder.js.map +1 -1
- package/dist/cjs/batch-query-builder.d.ts +36 -0
- package/dist/cjs/batch-query-builder.js +36 -0
- package/dist/cjs/batch-query-builder.js.map +1 -1
- package/dist/cjs/delete-query-builder.d.ts +17 -0
- package/dist/cjs/delete-query-builder.js +17 -0
- package/dist/cjs/delete-query-builder.js.map +1 -1
- package/dist/cjs/insert-query-builder.d.ts +68 -0
- package/dist/cjs/insert-query-builder.js +71 -0
- package/dist/cjs/insert-query-builder.js.map +1 -1
- package/dist/cjs/query-builder.d.ts +217 -0
- package/dist/cjs/query-builder.js +188 -0
- package/dist/cjs/query-builder.js.map +1 -1
- package/dist/cjs/selection-builder.d.ts +11 -0
- package/dist/cjs/selection-builder.js +11 -0
- package/dist/cjs/selection-builder.js.map +1 -1
- package/dist/cjs/update-query-builder.d.ts +32 -0
- package/dist/cjs/update-query-builder.js +32 -0
- package/dist/cjs/update-query-builder.js.map +1 -1
- package/dist/cjs/where-query-builder.d.ts +59 -0
- package/dist/cjs/where-query-builder.js +6 -0
- package/dist/cjs/where-query-builder.js.map +1 -1
- package/dist/esm/aggregation-query-builder.d.ts +92 -0
- package/dist/esm/aggregation-query-builder.js +92 -0
- package/dist/esm/aggregation-query-builder.js.map +1 -1
- package/dist/esm/batch-query-builder.d.ts +36 -0
- package/dist/esm/batch-query-builder.js +36 -0
- package/dist/esm/batch-query-builder.js.map +1 -1
- package/dist/esm/delete-query-builder.d.ts +17 -0
- package/dist/esm/delete-query-builder.js +17 -0
- package/dist/esm/delete-query-builder.js.map +1 -1
- package/dist/esm/insert-query-builder.d.ts +68 -0
- package/dist/esm/insert-query-builder.js +71 -0
- package/dist/esm/insert-query-builder.js.map +1 -1
- package/dist/esm/query-builder.d.ts +217 -0
- package/dist/esm/query-builder.js +188 -0
- package/dist/esm/query-builder.js.map +1 -1
- package/dist/esm/selection-builder.d.ts +11 -0
- package/dist/esm/selection-builder.js +11 -0
- package/dist/esm/selection-builder.js.map +1 -1
- package/dist/esm/update-query-builder.d.ts +32 -0
- package/dist/esm/update-query-builder.js +32 -0
- package/dist/esm/update-query-builder.js.map +1 -1
- package/dist/esm/where-query-builder.d.ts +59 -0
- package/dist/esm/where-query-builder.js +6 -0
- package/dist/esm/where-query-builder.js.map +1 -1
- package/dist/tsconfig.esm.tsbuildinfo +1 -1
- package/package.json +2 -2
|
@@ -3,8 +3,19 @@ import type { AnyDB } from './@types/internal-types.js';
|
|
|
3
3
|
import { LinkColumnNames } from './@types/query-builder.js';
|
|
4
4
|
import { Executor } from './executor.js';
|
|
5
5
|
import { QueryBuilder } from './query-builder.js';
|
|
6
|
+
/**
|
|
7
|
+
* A builder for creating subqueries on linked records.
|
|
8
|
+
* This is used internally by the `with` method on the `QueryBuilder`.
|
|
9
|
+
* @template DB - The database type.
|
|
10
|
+
* @template CurrentTableName - The name of the table the selection is starting from.
|
|
11
|
+
*/
|
|
6
12
|
export declare class SelectionBuilder<DB extends AnyDB, CurrentTableName extends keyof DB> {
|
|
7
13
|
_executor: Executor;
|
|
8
14
|
constructor(executor: Executor);
|
|
15
|
+
/**
|
|
16
|
+
* Creates a new query builder for a linked table.
|
|
17
|
+
* @param from - The name of the link field to select from.
|
|
18
|
+
* @returns A new `QueryBuilder` instance for the linked table.
|
|
19
|
+
*/
|
|
9
20
|
useLink<LinkName extends LinkColumnNames<DB[CurrentTableName]> & string>(from: LinkName): QueryBuilder<DB, DB[CurrentTableName][LinkName] extends LinkColumnType<any, boolean> ? DB[CurrentTableName][LinkName]["linkedTo"] : never, object, LinkName>;
|
|
10
21
|
}
|
|
@@ -2,11 +2,22 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.SelectionBuilder = void 0;
|
|
4
4
|
const query_builder_js_1 = require("./query-builder.js");
|
|
5
|
+
/**
|
|
6
|
+
* A builder for creating subqueries on linked records.
|
|
7
|
+
* This is used internally by the `with` method on the `QueryBuilder`.
|
|
8
|
+
* @template DB - The database type.
|
|
9
|
+
* @template CurrentTableName - The name of the table the selection is starting from.
|
|
10
|
+
*/
|
|
5
11
|
class SelectionBuilder {
|
|
6
12
|
_executor;
|
|
7
13
|
constructor(executor) {
|
|
8
14
|
this._executor = executor;
|
|
9
15
|
}
|
|
16
|
+
/**
|
|
17
|
+
* Creates a new query builder for a linked table.
|
|
18
|
+
* @param from - The name of the link field to select from.
|
|
19
|
+
* @returns A new `QueryBuilder` instance for the linked table.
|
|
20
|
+
*/
|
|
10
21
|
useLink(from) {
|
|
11
22
|
return new query_builder_js_1.QueryBuilder({
|
|
12
23
|
field: from,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"selection-builder.js","sourceRoot":"","sources":["../../src/selection-builder.ts"],"names":[],"mappings":";;;AAIA,yDAAkD;AAElD,MAAa,gBAAgB;IAI3B,SAAS,CAAW;IAEpB,YAAY,QAAkB;QAC5B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAED,OAAO,CACL,IAAc;QAEd,OAAO,IAAI,+BAAY,CAQrB;YACE,KAAK,EAAE,IAAI;YACX,MAAM,EAAE,EAAE;YACV,UAAU,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,EAAE;YAClD,SAAS,EAAE,MAAM;SAClB,EACD,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"selection-builder.js","sourceRoot":"","sources":["../../src/selection-builder.ts"],"names":[],"mappings":";;;AAIA,yDAAkD;AAElD;;;;;GAKG;AACH,MAAa,gBAAgB;IAI3B,SAAS,CAAW;IAEpB,YAAY,QAAkB;QAC5B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAED;;;;OAIG;IACH,OAAO,CACL,IAAc;QAEd,OAAO,IAAI,+BAAY,CAQrB;YACE,KAAK,EAAE,IAAI;YACX,MAAM,EAAE,EAAE;YACV,UAAU,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,EAAE;YAClD,SAAS,EAAE,MAAM;SAClB,EACD,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;CACF;AAnCD,4CAmCC"}
|
|
@@ -2,10 +2,42 @@ import type { AnyDB } from './@types/internal-types.js';
|
|
|
2
2
|
import type { Updatable, UpdateNode } from './@types/update.js';
|
|
3
3
|
import { Executor } from './executor.js';
|
|
4
4
|
import { FilterableQueryBuilder } from './where-query-builder.js';
|
|
5
|
+
/**
|
|
6
|
+
* A query builder for updating records in the database.
|
|
7
|
+
* @template DB - The database type.
|
|
8
|
+
* @template TableName - The name of the table to update.
|
|
9
|
+
*/
|
|
5
10
|
export declare class UpdateQueryBuilder<DB extends AnyDB, TableName extends keyof DB> extends FilterableQueryBuilder<DB, TableName> {
|
|
6
11
|
#private;
|
|
7
12
|
constructor(node: UpdateNode, executor: Executor);
|
|
13
|
+
/**
|
|
14
|
+
* Sets the values to update for the records that match the where clauses.
|
|
15
|
+
* @param values - An object containing the fields and their new values.
|
|
16
|
+
* @returns The `UpdateQueryBuilder` instance for chaining.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* ```typescript
|
|
20
|
+
* const { affectedRecords } = await qb
|
|
21
|
+
* .update('users')
|
|
22
|
+
* .set({ name: 'New Name' })
|
|
23
|
+
* .where('id', '=', 1)
|
|
24
|
+
* .execute();
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
8
27
|
set(values: Updatable<DB[TableName]>): UpdateQueryBuilder<DB, TableName>;
|
|
28
|
+
/**
|
|
29
|
+
* Executes the update query.
|
|
30
|
+
* @returns A promise that resolves with the number of affected records.
|
|
31
|
+
*
|
|
32
|
+
* @example
|
|
33
|
+
* ```typescript
|
|
34
|
+
* const { affectedRecords } = await qb
|
|
35
|
+
* .update('users')
|
|
36
|
+
* .set({ name: 'New Name' })
|
|
37
|
+
* .where('id', '=', 1)
|
|
38
|
+
* .execute();
|
|
39
|
+
* ```
|
|
40
|
+
*/
|
|
9
41
|
execute(): Promise<{
|
|
10
42
|
affectedRecords: number;
|
|
11
43
|
}>;
|
|
@@ -2,18 +2,50 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.UpdateQueryBuilder = void 0;
|
|
4
4
|
const where_query_builder_js_1 = require("./where-query-builder.js");
|
|
5
|
+
/**
|
|
6
|
+
* A query builder for updating records in the database.
|
|
7
|
+
* @template DB - The database type.
|
|
8
|
+
* @template TableName - The name of the table to update.
|
|
9
|
+
*/
|
|
5
10
|
class UpdateQueryBuilder extends where_query_builder_js_1.FilterableQueryBuilder {
|
|
6
11
|
#node;
|
|
7
12
|
constructor(node, executor) {
|
|
8
13
|
super(node, executor);
|
|
9
14
|
this.#node = node;
|
|
10
15
|
}
|
|
16
|
+
/**
|
|
17
|
+
* Sets the values to update for the records that match the where clauses.
|
|
18
|
+
* @param values - An object containing the fields and their new values.
|
|
19
|
+
* @returns The `UpdateQueryBuilder` instance for chaining.
|
|
20
|
+
*
|
|
21
|
+
* @example
|
|
22
|
+
* ```typescript
|
|
23
|
+
* const { affectedRecords } = await qb
|
|
24
|
+
* .update('users')
|
|
25
|
+
* .set({ name: 'New Name' })
|
|
26
|
+
* .where('id', '=', 1)
|
|
27
|
+
* .execute();
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
11
30
|
set(values) {
|
|
12
31
|
return new UpdateQueryBuilder({
|
|
13
32
|
...this.#node,
|
|
14
33
|
values,
|
|
15
34
|
}, this._executor);
|
|
16
35
|
}
|
|
36
|
+
/**
|
|
37
|
+
* Executes the update query.
|
|
38
|
+
* @returns A promise that resolves with the number of affected records.
|
|
39
|
+
*
|
|
40
|
+
* @example
|
|
41
|
+
* ```typescript
|
|
42
|
+
* const { affectedRecords } = await qb
|
|
43
|
+
* .update('users')
|
|
44
|
+
* .set({ name: 'New Name' })
|
|
45
|
+
* .where('id', '=', 1)
|
|
46
|
+
* .execute();
|
|
47
|
+
* ```
|
|
48
|
+
*/
|
|
17
49
|
async execute() {
|
|
18
50
|
const response = await this._executor.execute(this);
|
|
19
51
|
return response[0];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"update-query-builder.js","sourceRoot":"","sources":["../../src/update-query-builder.ts"],"names":[],"mappings":";;;AAGA,qEAAkE;AAElE,MAAa,kBAGX,SAAQ,+CAAqC;IAC7C,KAAK,CAAa;IAElB,YAAY,IAAgB,EAAE,QAAkB;QAC9C,KAAK,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QACtB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAED,GAAG,CAAC,MAAgC;QAClC,OAAO,IAAI,kBAAkB,CAC3B;YACE,GAAG,IAAI,CAAC,KAAK;YACb,MAAM;SACP,EACD,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,QAAQ,GACZ,MAAM,IAAI,CAAC,SAAS,CAAC,OAAO,CAAgC,IAAI,CAAC,CAAC;QAEpE,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IAED,OAAO;QACL,MAAM,KAAK,GAAG,6DAA6D,CAAC;QAE5E,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QAE3C,OAAO;YACL,KAAK;YACL,SAAS,EAAE;gBACT,QAAQ;aACT;SACF,CAAC;IACJ,CAAC;IAED,gBAAgB;QACd,OAAO;YACL,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS;YAC/B,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM;YACzB,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC;gBAC7C,CAAC,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;gBACvC,CAAC,CAAC,EAAE,CAAC;SACR,CAAC;IACJ,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"update-query-builder.js","sourceRoot":"","sources":["../../src/update-query-builder.ts"],"names":[],"mappings":";;;AAGA,qEAAkE;AAElE;;;;GAIG;AACH,MAAa,kBAGX,SAAQ,+CAAqC;IAC7C,KAAK,CAAa;IAElB,YAAY,IAAgB,EAAE,QAAkB;QAC9C,KAAK,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QACtB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,GAAG,CAAC,MAAgC;QAClC,OAAO,IAAI,kBAAkB,CAC3B;YACE,GAAG,IAAI,CAAC,KAAK;YACb,MAAM;SACP,EACD,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,KAAK,CAAC,OAAO;QACX,MAAM,QAAQ,GACZ,MAAM,IAAI,CAAC,SAAS,CAAC,OAAO,CAAgC,IAAI,CAAC,CAAC;QAEpE,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IAED,OAAO;QACL,MAAM,KAAK,GAAG,6DAA6D,CAAC;QAE5E,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QAE3C,OAAO;YACL,KAAK;YACL,SAAS,EAAE;gBACT,QAAQ;aACT;SACF,CAAC;IACJ,CAAC;IAED,gBAAgB;QACd,OAAO;YACL,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS;YAC/B,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM;YACzB,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC;gBAC7C,CAAC,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;gBACvC,CAAC,CAAC,EAAE,CAAC;SACR,CAAC;IACJ,CAAC;CACF;AA9ED,gDA8EC"}
|
|
@@ -2,12 +2,71 @@ import { LinkColumnType } from '@taylordb/shared';
|
|
|
2
2
|
import { AnyDB, FilterableNode } from './@types/internal-types.js';
|
|
3
3
|
import { ColumnNames } from './@types/query-builder.js';
|
|
4
4
|
import { Executor } from './executor.js';
|
|
5
|
+
/**
|
|
6
|
+
* A base class for query builders that support filtering.
|
|
7
|
+
* It provides the `where` and `orWhere` methods.
|
|
8
|
+
* @template DB - The database type.
|
|
9
|
+
* @template TableName - The name of the table to query.
|
|
10
|
+
*/
|
|
5
11
|
export declare class FilterableQueryBuilder<DB extends AnyDB, TableName extends keyof DB> {
|
|
6
12
|
_node: FilterableNode;
|
|
7
13
|
_executor: Executor;
|
|
8
14
|
constructor(node: FilterableNode, executor: Executor);
|
|
15
|
+
/**
|
|
16
|
+
* Adds a `where` clause to the query.
|
|
17
|
+
* This can be a simple condition, a nested query, or a cross-filter on a linked table.
|
|
18
|
+
*
|
|
19
|
+
* @param field - The field to filter on.
|
|
20
|
+
* @param operator - The filter operator.
|
|
21
|
+
* @param value - The value to filter by.
|
|
22
|
+
* @returns The query builder instance for chaining.
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* ```typescript
|
|
26
|
+
* const users = await qb
|
|
27
|
+
* .selectFrom('users')
|
|
28
|
+
* .where('name', '=', 'John Doe')
|
|
29
|
+
* .execute();
|
|
30
|
+
* ```
|
|
31
|
+
*
|
|
32
|
+
* @example
|
|
33
|
+
* ```typescript
|
|
34
|
+
* const users = await qb
|
|
35
|
+
* .selectFrom('users')
|
|
36
|
+
* .where((qb) =>
|
|
37
|
+
* qb.where('name', '=', 'John Doe').orWhere('email', '=', 'john.doe@example.com')
|
|
38
|
+
* )
|
|
39
|
+
* .execute();
|
|
40
|
+
* ```
|
|
41
|
+
*
|
|
42
|
+
* @example
|
|
43
|
+
* ```typescript
|
|
44
|
+
* const users = await qb
|
|
45
|
+
* .selectFrom('users')
|
|
46
|
+
* .where('posts', 'hasAnyOf', (qb) => qb.where('isPublished', '=', true))
|
|
47
|
+
* .execute();
|
|
48
|
+
* ```
|
|
49
|
+
*/
|
|
9
50
|
where<TField extends ColumnNames<DB[TableName]> & string, TOperator extends keyof DB[TableName][TField]['filters']>(field: TField, operator: TOperator, value: DB[TableName][TField] extends LinkColumnType<any, boolean> ? ((qb: FilterableQueryBuilder<DB, DB[TableName][TField] extends LinkColumnType<any, boolean> ? DB[TableName][TField]['linkedTo'] : never>) => FilterableQueryBuilder<DB, DB[TableName][TField] extends LinkColumnType<any, boolean> ? DB[TableName][TField]['linkedTo'] : never>) | DB[TableName][TField]['filters'][TOperator] : DB[TableName][TField]['filters'][TOperator]): this;
|
|
10
51
|
where<C extends (builder: WhereQueryBuilder<DB, TableName>) => WhereQueryBuilder<DB, TableName>>(column: C): this;
|
|
52
|
+
/**
|
|
53
|
+
* Adds an `orWhere` clause to the query.
|
|
54
|
+
* This is similar to `where`, but the condition will be joined with `OR`.
|
|
55
|
+
*
|
|
56
|
+
* @param field - The field to filter on.
|
|
57
|
+
* @param operator - The filter operator.
|
|
58
|
+
* @param value - The value to filter by.
|
|
59
|
+
* @returns The query builder instance for chaining.
|
|
60
|
+
*
|
|
61
|
+
* @example
|
|
62
|
+
* ```typescript
|
|
63
|
+
* const users = await qb
|
|
64
|
+
* .selectFrom('users')
|
|
65
|
+
* .where('name', '=', 'John Doe')
|
|
66
|
+
* .orWhere('name', '=', 'Jane Doe')
|
|
67
|
+
* .execute();
|
|
68
|
+
* ```
|
|
69
|
+
*/
|
|
11
70
|
orWhere<TField extends ColumnNames<DB[TableName]> & string, TOperator extends keyof DB[TableName][TField]['filters']>(field: TField, operator: TOperator, value: DB[TableName][TField] extends LinkColumnType<any, boolean> ? (qb: FilterableQueryBuilder<DB, DB[TableName][TField] extends LinkColumnType<any, boolean> ? DB[TableName][TField]['linkedTo'] : never>) => FilterableQueryBuilder<DB, DB[TableName][TField] extends LinkColumnType<any, boolean> ? DB[TableName][TField]['linkedTo'] : never> | DB[TableName][TField]['filters'][TOperator] : DB[TableName][TField]['filters'][TOperator]): this;
|
|
12
71
|
orWhere<C extends (builder: WhereQueryBuilder<DB, TableName>) => WhereQueryBuilder<DB, TableName>>(column: C): this;
|
|
13
72
|
}
|
|
@@ -2,6 +2,12 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.WhereQueryBuilder = exports.FilterableQueryBuilder = void 0;
|
|
4
4
|
const selection_builder_js_1 = require("./selection-builder.js");
|
|
5
|
+
/**
|
|
6
|
+
* A base class for query builders that support filtering.
|
|
7
|
+
* It provides the `where` and `orWhere` methods.
|
|
8
|
+
* @template DB - The database type.
|
|
9
|
+
* @template TableName - The name of the table to query.
|
|
10
|
+
*/
|
|
5
11
|
class FilterableQueryBuilder {
|
|
6
12
|
_executor;
|
|
7
13
|
constructor(node, executor) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"where-query-builder.js","sourceRoot":"","sources":["../../src/where-query-builder.ts"],"names":[],"mappings":";;;AAIA,iEAA0D;AAE1D,MAAa,sBAAsB;IAKjC,SAAS,CAAW;IAEpB,YAAY,IAAoB,EAAE,QAAkB;QAClD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5B,CAAC;
|
|
1
|
+
{"version":3,"file":"where-query-builder.js","sourceRoot":"","sources":["../../src/where-query-builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,23 +2,115 @@ import type { AggregateNode, AggregateRecord } from './@types/aggregate.js';
|
|
|
2
2
|
import type { AnyDB } from './@types/internal-types.js';
|
|
3
3
|
import { Executor } from './executor.js';
|
|
4
4
|
import { FilterableQueryBuilder } from './where-query-builder.js';
|
|
5
|
+
/**
|
|
6
|
+
* A query builder for performing aggregation queries.
|
|
7
|
+
* @template DB - The database type.
|
|
8
|
+
* @template TableName - The name of the table to aggregate from.
|
|
9
|
+
* @template TGroupBy - The fields to group by.
|
|
10
|
+
* @template TAggregations - The aggregations to perform.
|
|
11
|
+
*/
|
|
5
12
|
export declare class AggregationQueryBuilder<DB extends AnyDB, TableName extends keyof DB, TGroupBy extends readonly (keyof DB[TableName] & string)[] = [], TAggregations extends {
|
|
6
13
|
[K in keyof DB[TableName] & string]?: readonly (keyof DB[TableName][K]['aggregations'])[];
|
|
7
14
|
} = object> extends FilterableQueryBuilder<DB, TableName> {
|
|
8
15
|
#private;
|
|
9
16
|
constructor(node: AggregateNode, executor: Executor);
|
|
17
|
+
/**
|
|
18
|
+
* Groups the results by a specified field.
|
|
19
|
+
* @param field - The field to group by.
|
|
20
|
+
* @param direction - The sort direction for the grouping.
|
|
21
|
+
* @returns A new `AggregationQueryBuilder` instance with the grouping applied.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* ```typescript
|
|
25
|
+
* const userCounts = await qb
|
|
26
|
+
* .aggregateFrom('users')
|
|
27
|
+
* .groupBy('role')
|
|
28
|
+
* .withAggregates({ id: ['count'] })
|
|
29
|
+
* .execute();
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
10
32
|
groupBy<const TField extends keyof DB[TableName] & string>(field: TField, direction?: 'asc' | 'desc'): AggregationQueryBuilder<DB, TableName, [
|
|
11
33
|
...TGroupBy,
|
|
12
34
|
TField
|
|
13
35
|
], TAggregations>;
|
|
36
|
+
/**
|
|
37
|
+
* Specifies the aggregations to perform.
|
|
38
|
+
* @param aggregates - An object where the keys are field names and the values are arrays of aggregation functions.
|
|
39
|
+
* @returns A new `AggregationQueryBuilder` instance with the aggregations applied.
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```typescript
|
|
43
|
+
* const userStats = await qb
|
|
44
|
+
* .aggregateFrom('users')
|
|
45
|
+
* .withAggregates({
|
|
46
|
+
* id: ['count'],
|
|
47
|
+
* age: ['avg', 'sum'],
|
|
48
|
+
* })
|
|
49
|
+
* .execute();
|
|
50
|
+
* ```
|
|
51
|
+
*/
|
|
14
52
|
withAggregates<const T extends {
|
|
15
53
|
[K in keyof DB[TableName] & string]?: readonly (keyof DB[TableName][K]['aggregations'])[];
|
|
16
54
|
}>(aggregates: T): AggregationQueryBuilder<DB, TableName, TGroupBy, TAggregations & T>;
|
|
55
|
+
/**
|
|
56
|
+
* Sets the maximum number of records to return.
|
|
57
|
+
* @param count - The maximum number of records.
|
|
58
|
+
* @returns A new `AggregationQueryBuilder` instance with the limit applied.
|
|
59
|
+
*/
|
|
17
60
|
limit(count: number): AggregationQueryBuilder<DB, TableName, TGroupBy, TAggregations>;
|
|
61
|
+
/**
|
|
62
|
+
* Sets the number of records to skip.
|
|
63
|
+
* @param count - The number of records to skip.
|
|
64
|
+
* @returns A new `AggregationQueryBuilder` instance with the offset applied.
|
|
65
|
+
*/
|
|
18
66
|
offset(count: number): AggregationQueryBuilder<DB, TableName, TGroupBy, TAggregations>;
|
|
67
|
+
/**
|
|
68
|
+
* Paginates the results.
|
|
69
|
+
* @param page - The page number to retrieve.
|
|
70
|
+
* @param limit - The number of records per page.
|
|
71
|
+
* @returns A new `AggregationQueryBuilder` instance with pagination applied.
|
|
72
|
+
*/
|
|
19
73
|
paginate(page: number, limit: number): AggregationQueryBuilder<DB, TableName, TGroupBy, TAggregations>;
|
|
74
|
+
/**
|
|
75
|
+
* Sorts the results by a specified field.
|
|
76
|
+
* @param field - The field to sort by.
|
|
77
|
+
* @param direction - The sort direction ('asc' or 'desc').
|
|
78
|
+
* @returns A new `AggregationQueryBuilder` instance with the sorting applied.
|
|
79
|
+
*/
|
|
20
80
|
orderBy(field: keyof DB[TableName], direction?: 'asc' | 'desc'): AggregationQueryBuilder<DB, TableName, TGroupBy, TAggregations>;
|
|
81
|
+
/**
|
|
82
|
+
* Executes the aggregation query.
|
|
83
|
+
* @returns A promise that resolves with an array of the aggregation results.
|
|
84
|
+
*
|
|
85
|
+
* @example
|
|
86
|
+
* ```typescript
|
|
87
|
+
* const userCounts = await qb
|
|
88
|
+
* .aggregateFrom('users')
|
|
89
|
+
* .groupBy('role')
|
|
90
|
+
* .withAggregates({ id: ['count'] })
|
|
91
|
+
* .execute();
|
|
92
|
+
* ```
|
|
93
|
+
*/
|
|
21
94
|
execute(): Promise<AggregateRecord<DB, TableName, TGroupBy, TAggregations>[]>;
|
|
95
|
+
/**
|
|
96
|
+
* Subscribes to the results of the aggregation query.
|
|
97
|
+
* @param callback - A callback function that will be called with the results of the aggregation query.
|
|
98
|
+
* @returns A function to unsubscribe from the query.
|
|
99
|
+
*
|
|
100
|
+
* @example
|
|
101
|
+
* ```typescript
|
|
102
|
+
* const unsubscribe = qb
|
|
103
|
+
* .aggregateFrom('users')
|
|
104
|
+
* .groupBy('role')
|
|
105
|
+
* .withAggregates({ id: ['count'] })
|
|
106
|
+
* .subscribe((userCounts) => {
|
|
107
|
+
* console.log('User counts by role:', userCounts);
|
|
108
|
+
* });
|
|
109
|
+
*
|
|
110
|
+
* // To stop listening for updates
|
|
111
|
+
* unsubscribe();
|
|
112
|
+
* ```
|
|
113
|
+
*/
|
|
22
114
|
subscribe(callback: (result: AggregateRecord<DB, TableName, TGroupBy, TAggregations>[]) => void): Promise<{
|
|
23
115
|
unsubscribe: () => Promise<void>;
|
|
24
116
|
}>;
|
|
@@ -1,10 +1,32 @@
|
|
|
1
1
|
import { FilterableQueryBuilder } from './where-query-builder.js';
|
|
2
|
+
/**
|
|
3
|
+
* A query builder for performing aggregation queries.
|
|
4
|
+
* @template DB - The database type.
|
|
5
|
+
* @template TableName - The name of the table to aggregate from.
|
|
6
|
+
* @template TGroupBy - The fields to group by.
|
|
7
|
+
* @template TAggregations - The aggregations to perform.
|
|
8
|
+
*/
|
|
2
9
|
export class AggregationQueryBuilder extends FilterableQueryBuilder {
|
|
3
10
|
#node;
|
|
4
11
|
constructor(node, executor) {
|
|
5
12
|
super(node, executor);
|
|
6
13
|
this.#node = node;
|
|
7
14
|
}
|
|
15
|
+
/**
|
|
16
|
+
* Groups the results by a specified field.
|
|
17
|
+
* @param field - The field to group by.
|
|
18
|
+
* @param direction - The sort direction for the grouping.
|
|
19
|
+
* @returns A new `AggregationQueryBuilder` instance with the grouping applied.
|
|
20
|
+
*
|
|
21
|
+
* @example
|
|
22
|
+
* ```typescript
|
|
23
|
+
* const userCounts = await qb
|
|
24
|
+
* .aggregateFrom('users')
|
|
25
|
+
* .groupBy('role')
|
|
26
|
+
* .withAggregates({ id: ['count'] })
|
|
27
|
+
* .execute();
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
8
30
|
groupBy(field, direction = 'asc') {
|
|
9
31
|
const newGrouping = {
|
|
10
32
|
field,
|
|
@@ -15,6 +37,22 @@ export class AggregationQueryBuilder extends FilterableQueryBuilder {
|
|
|
15
37
|
groupings: [...(this.#node.groupings || []), newGrouping],
|
|
16
38
|
}, this._executor);
|
|
17
39
|
}
|
|
40
|
+
/**
|
|
41
|
+
* Specifies the aggregations to perform.
|
|
42
|
+
* @param aggregates - An object where the keys are field names and the values are arrays of aggregation functions.
|
|
43
|
+
* @returns A new `AggregationQueryBuilder` instance with the aggregations applied.
|
|
44
|
+
*
|
|
45
|
+
* @example
|
|
46
|
+
* ```typescript
|
|
47
|
+
* const userStats = await qb
|
|
48
|
+
* .aggregateFrom('users')
|
|
49
|
+
* .withAggregates({
|
|
50
|
+
* id: ['count'],
|
|
51
|
+
* age: ['avg', 'sum'],
|
|
52
|
+
* })
|
|
53
|
+
* .execute();
|
|
54
|
+
* ```
|
|
55
|
+
*/
|
|
18
56
|
withAggregates(aggregates) {
|
|
19
57
|
const newAggregates = { ...this.#node.aggregations };
|
|
20
58
|
for (const key in aggregates) {
|
|
@@ -25,21 +63,43 @@ export class AggregationQueryBuilder extends FilterableQueryBuilder {
|
|
|
25
63
|
aggregations: newAggregates,
|
|
26
64
|
}, this._executor);
|
|
27
65
|
}
|
|
66
|
+
/**
|
|
67
|
+
* Sets the maximum number of records to return.
|
|
68
|
+
* @param count - The maximum number of records.
|
|
69
|
+
* @returns A new `AggregationQueryBuilder` instance with the limit applied.
|
|
70
|
+
*/
|
|
28
71
|
limit(count) {
|
|
29
72
|
return new AggregationQueryBuilder({
|
|
30
73
|
...this.#node,
|
|
31
74
|
pagination: { ...this.#node.pagination, limit: count },
|
|
32
75
|
}, this._executor);
|
|
33
76
|
}
|
|
77
|
+
/**
|
|
78
|
+
* Sets the number of records to skip.
|
|
79
|
+
* @param count - The number of records to skip.
|
|
80
|
+
* @returns A new `AggregationQueryBuilder` instance with the offset applied.
|
|
81
|
+
*/
|
|
34
82
|
offset(count) {
|
|
35
83
|
return new AggregationQueryBuilder({
|
|
36
84
|
...this.#node,
|
|
37
85
|
pagination: { ...this.#node.pagination, offset: count },
|
|
38
86
|
}, this._executor);
|
|
39
87
|
}
|
|
88
|
+
/**
|
|
89
|
+
* Paginates the results.
|
|
90
|
+
* @param page - The page number to retrieve.
|
|
91
|
+
* @param limit - The number of records per page.
|
|
92
|
+
* @returns A new `AggregationQueryBuilder` instance with pagination applied.
|
|
93
|
+
*/
|
|
40
94
|
paginate(page, limit) {
|
|
41
95
|
return this.offset((page - 1) * limit).limit(limit);
|
|
42
96
|
}
|
|
97
|
+
/**
|
|
98
|
+
* Sorts the results by a specified field.
|
|
99
|
+
* @param field - The field to sort by.
|
|
100
|
+
* @param direction - The sort direction ('asc' or 'desc').
|
|
101
|
+
* @returns A new `AggregationQueryBuilder` instance with the sorting applied.
|
|
102
|
+
*/
|
|
43
103
|
orderBy(field, direction = 'asc') {
|
|
44
104
|
const newSorting = {
|
|
45
105
|
field: field,
|
|
@@ -50,10 +110,42 @@ export class AggregationQueryBuilder extends FilterableQueryBuilder {
|
|
|
50
110
|
sorting: [...(this.#node.sorting || []), newSorting],
|
|
51
111
|
}, this._executor);
|
|
52
112
|
}
|
|
113
|
+
/**
|
|
114
|
+
* Executes the aggregation query.
|
|
115
|
+
* @returns A promise that resolves with an array of the aggregation results.
|
|
116
|
+
*
|
|
117
|
+
* @example
|
|
118
|
+
* ```typescript
|
|
119
|
+
* const userCounts = await qb
|
|
120
|
+
* .aggregateFrom('users')
|
|
121
|
+
* .groupBy('role')
|
|
122
|
+
* .withAggregates({ id: ['count'] })
|
|
123
|
+
* .execute();
|
|
124
|
+
* ```
|
|
125
|
+
*/
|
|
53
126
|
async execute() {
|
|
54
127
|
const response = await this._executor.execute(this);
|
|
55
128
|
return response;
|
|
56
129
|
}
|
|
130
|
+
/**
|
|
131
|
+
* Subscribes to the results of the aggregation query.
|
|
132
|
+
* @param callback - A callback function that will be called with the results of the aggregation query.
|
|
133
|
+
* @returns A function to unsubscribe from the query.
|
|
134
|
+
*
|
|
135
|
+
* @example
|
|
136
|
+
* ```typescript
|
|
137
|
+
* const unsubscribe = qb
|
|
138
|
+
* .aggregateFrom('users')
|
|
139
|
+
* .groupBy('role')
|
|
140
|
+
* .withAggregates({ id: ['count'] })
|
|
141
|
+
* .subscribe((userCounts) => {
|
|
142
|
+
* console.log('User counts by role:', userCounts);
|
|
143
|
+
* });
|
|
144
|
+
*
|
|
145
|
+
* // To stop listening for updates
|
|
146
|
+
* unsubscribe();
|
|
147
|
+
* ```
|
|
148
|
+
*/
|
|
57
149
|
subscribe(callback) {
|
|
58
150
|
return this._executor.subscribe([this], callback);
|
|
59
151
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aggregation-query-builder.js","sourceRoot":"","sources":["../../src/aggregation-query-builder.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"aggregation-query-builder.js","sourceRoot":"","sources":["../../src/aggregation-query-builder.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAElE;;;;;;GAMG;AACH,MAAM,OAAO,uBAQX,SAAQ,sBAAqC;IAC7C,KAAK,CAAgB;IAErB,YAAY,IAAmB,EAAE,QAAkB;QACjD,KAAK,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QACtB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAED;;;;;;;;;;;;;;OAcG;IACH,OAAO,CACL,KAAa,EACb,YAA4B,KAAK;QAOjC,MAAM,WAAW,GAAkC;YACjD,KAAK;YACL,SAAS;SACV,CAAC;QAEF,OAAO,IAAI,uBAAuB,CAChC;YACE,GAAG,IAAI,CAAC,KAAK;YACb,SAAS,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,IAAI,EAAE,CAAC,EAAE,WAAW,CAAC;SAC1D,EACD,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;;;OAeG;IACH,cAAc,CAMZ,UAAa;QAEb,MAAM,aAAa,GAAG,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QACrD,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAC7B,aAAa,CAAC,GAAG,CAAC,GAAG,UAAU,CAAC,GAAG,CAAE,CAAC,GAAG,CACvC,SAAS,CAAC,EAAE,CAAC,SAAmB,CACjC,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,uBAAuB,CAChC;YACE,GAAG,IAAI,CAAC,KAAK;YACb,YAAY,EAAE,aAAa;SAC5B,EACD,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,KAAK,CACH,KAAa;QAEb,OAAO,IAAI,uBAAuB,CAChC;YACE,GAAG,IAAI,CAAC,KAAK;YACb,UAAU,EAAE,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE;SACvD,EACD,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,MAAM,CACJ,KAAa;QAEb,OAAO,IAAI,uBAAuB,CAChC;YACE,GAAG,IAAI,CAAC,KAAK;YACb,UAAU,EAAE,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE;SACxD,EACD,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;IAED;;;;;OAKG;IACH,QAAQ,CACN,IAAY,EACZ,KAAa;QAEb,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACtD,CAAC;IAED;;;;;OAKG;IACH,OAAO,CACL,KAA0B,EAC1B,YAA4B,KAAK;QAEjC,MAAM,UAAU,GAA+B;YAC7C,KAAK,EAAE,KAAe;YACtB,SAAS;SACV,CAAC;QAEF,OAAO,IAAI,uBAAuB,CAChC;YACE,GAAG,IAAI,CAAC,KAAK;YACb,OAAO,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE,UAAU,CAAC;SACrD,EACD,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,KAAK,CAAC,OAAO;QAGX,MAAM,QAAQ,GACZ,MAAM,IAAI,CAAC,SAAS,CAAC,OAAO,CAE1B,IAAI,CAAC,CAAC;QACV,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;;;;;;;;;;;;;;;;OAkBG;IACH,SAAS,CACP,QAES;QAET,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,EAAE,QAAQ,CAAC,CAAC;IACpD,CAAC;IAED,OAAO;QACL,MAAM,KAAK,GAAG,6DAA6D,CAAC;QAC5E,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QAC3C,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC;IAC5C,CAAC;IAED,gBAAgB;QACd,OAAO;YACL,IAAI,EAAE,aAAa;YACnB,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS;YAC/B,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS;YAC/B,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY;YACrC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC;gBAC7C,CAAC,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;gBACvC,CAAC,CAAC,EAAE,CAAC;YACP,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACvE,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC/D,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -10,12 +10,48 @@ type InferExecuteResult<TBuilder> = TBuilder extends {
|
|
|
10
10
|
execute: () => Promise<any>;
|
|
11
11
|
} ? Awaited<ReturnType<TBuilder['execute']>> : never;
|
|
12
12
|
export type AreAllBuildersSubscribable<TBuilders extends readonly AnyQueryBuilder[]> = TBuilders[number] extends AnySubscribableQueryBuilder ? true : false;
|
|
13
|
+
/**
|
|
14
|
+
* A query builder for executing multiple queries in a single batch.
|
|
15
|
+
* @template TBuilders - An array of query builders to execute.
|
|
16
|
+
*/
|
|
13
17
|
export declare class BatchQueryBuilder<const TBuilders extends readonly AnyQueryBuilder[]> {
|
|
14
18
|
#private;
|
|
15
19
|
constructor(builders: TBuilders, executor: Executor);
|
|
20
|
+
/**
|
|
21
|
+
* Executes the batch query.
|
|
22
|
+
* @returns A promise that resolves with an array of the results from each query in the batch.
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* ```typescript
|
|
26
|
+
* const [users, newUser] = await qb.batch([
|
|
27
|
+
* qb.selectFrom('users').select(['id', 'name']),
|
|
28
|
+
* qb.insertInto('users').values({ name: 'New User' }).returning(['id', 'name']),
|
|
29
|
+
* ]).execute();
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
16
32
|
execute(): Promise<{
|
|
17
33
|
-readonly [K in keyof TBuilders]: InferExecuteResult<TBuilders[K]>;
|
|
18
34
|
}>;
|
|
35
|
+
/**
|
|
36
|
+
* Subscribes to the results of the batch query.
|
|
37
|
+
* This is only possible if all queries in the batch are subscribable (select and aggregate).
|
|
38
|
+
* @param callback - A callback function that will be called with the results of the batch query.
|
|
39
|
+
* @returns A function to unsubscribe from the query.
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```typescript
|
|
43
|
+
* const unsubscribe = qb.batch([
|
|
44
|
+
* qb.selectFrom('users').select(['id', 'name']),
|
|
45
|
+
* qb.aggregateFrom('users').groupBy('role').withAggregates({ id: ['count'] }),
|
|
46
|
+
* ]).subscribe(([users, userAggregates]) => {
|
|
47
|
+
* console.log('Users:', users);
|
|
48
|
+
* console.log('User Aggregates:', userAggregates);
|
|
49
|
+
* });
|
|
50
|
+
*
|
|
51
|
+
* // To stop listening for updates
|
|
52
|
+
* unsubscribe();
|
|
53
|
+
* ```
|
|
54
|
+
*/
|
|
19
55
|
subscribe(callback: (...results: {
|
|
20
56
|
-readonly [K in keyof TBuilders]: InferExecuteResult<TBuilders[K]>;
|
|
21
57
|
}) => void): Promise<{
|
|
@@ -1,5 +1,9 @@
|
|
|
1
1
|
import { AggregationQueryBuilder } from './aggregation-query-builder.js';
|
|
2
2
|
import { QueryBuilder } from './query-builder.js';
|
|
3
|
+
/**
|
|
4
|
+
* A query builder for executing multiple queries in a single batch.
|
|
5
|
+
* @template TBuilders - An array of query builders to execute.
|
|
6
|
+
*/
|
|
3
7
|
export class BatchQueryBuilder {
|
|
4
8
|
#builders;
|
|
5
9
|
#executor;
|
|
@@ -7,9 +11,41 @@ export class BatchQueryBuilder {
|
|
|
7
11
|
this.#builders = builders;
|
|
8
12
|
this.#executor = executor;
|
|
9
13
|
}
|
|
14
|
+
/**
|
|
15
|
+
* Executes the batch query.
|
|
16
|
+
* @returns A promise that resolves with an array of the results from each query in the batch.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* ```typescript
|
|
20
|
+
* const [users, newUser] = await qb.batch([
|
|
21
|
+
* qb.selectFrom('users').select(['id', 'name']),
|
|
22
|
+
* qb.insertInto('users').values({ name: 'New User' }).returning(['id', 'name']),
|
|
23
|
+
* ]).execute();
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
10
26
|
async execute() {
|
|
11
27
|
return this.#executor.execute(this);
|
|
12
28
|
}
|
|
29
|
+
/**
|
|
30
|
+
* Subscribes to the results of the batch query.
|
|
31
|
+
* This is only possible if all queries in the batch are subscribable (select and aggregate).
|
|
32
|
+
* @param callback - A callback function that will be called with the results of the batch query.
|
|
33
|
+
* @returns A function to unsubscribe from the query.
|
|
34
|
+
*
|
|
35
|
+
* @example
|
|
36
|
+
* ```typescript
|
|
37
|
+
* const unsubscribe = qb.batch([
|
|
38
|
+
* qb.selectFrom('users').select(['id', 'name']),
|
|
39
|
+
* qb.aggregateFrom('users').groupBy('role').withAggregates({ id: ['count'] }),
|
|
40
|
+
* ]).subscribe(([users, userAggregates]) => {
|
|
41
|
+
* console.log('Users:', users);
|
|
42
|
+
* console.log('User Aggregates:', userAggregates);
|
|
43
|
+
* });
|
|
44
|
+
*
|
|
45
|
+
* // To stop listening for updates
|
|
46
|
+
* unsubscribe();
|
|
47
|
+
* ```
|
|
48
|
+
*/
|
|
13
49
|
subscribe(callback) {
|
|
14
50
|
const builders = this.#builders.filter(builder => builder instanceof AggregationQueryBuilder ||
|
|
15
51
|
builder instanceof QueryBuilder);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"batch-query-builder.js","sourceRoot":"","sources":["../../src/batch-query-builder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,gCAAgC,CAAC;AAIzE,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAuBlD,MAAM,OAAO,iBAAiB;IAG5B,SAAS,CAAY;IACrB,SAAS,CAAW;IAEpB,YAAY,QAAmB,EAAE,QAAkB;QACjD,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,OAAO;QAGX,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,SAAS,CACP,QAIS;QAET,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CACpC,OAAO,CAAC,EAAE,CACR,OAAO,YAAY,uBAAuB;YAC1C,OAAO,YAAY,YAAY,CAClC,CAAC;QAEF,IAAI,QAAQ,CAAC,MAAM,KAAK,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;YAC9C,MAAM,IAAI,KAAK,CACb,wEAAwE,CACzE,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,QAAQ,EAAE,QAAe,CAAC,CAAC;IAC7D,CAAC;IAED,OAAO;QACL,MAAM,KAAK,GAAG,6DAA6D,CAAC;QAE5E,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;YAC5C,OAAO,OAAO,CAAC,gBAAgB,EAAE,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,OAAO;YACL,KAAK;YACL,SAAS,EAAE;gBACT,QAAQ;aACT;SACF,CAAC;IACJ,CAAC;CACF"}
|
|
1
|
+
{"version":3,"file":"batch-query-builder.js","sourceRoot":"","sources":["../../src/batch-query-builder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,gCAAgC,CAAC;AAIzE,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAuBlD;;;GAGG;AACH,MAAM,OAAO,iBAAiB;IAG5B,SAAS,CAAY;IACrB,SAAS,CAAW;IAEpB,YAAY,QAAmB,EAAE,QAAkB;QACjD,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAED;;;;;;;;;;;OAWG;IACH,KAAK,CAAC,OAAO;QAGX,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED;;;;;;;;;;;;;;;;;;;OAmBG;IACH,SAAS,CACP,QAIS;QAET,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CACpC,OAAO,CAAC,EAAE,CACR,OAAO,YAAY,uBAAuB;YAC1C,OAAO,YAAY,YAAY,CAClC,CAAC;QAEF,IAAI,QAAQ,CAAC,MAAM,KAAK,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;YAC9C,MAAM,IAAI,KAAK,CACb,wEAAwE,CACzE,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,QAAQ,EAAE,QAAe,CAAC,CAAC;IAC7D,CAAC;IAED,OAAO;QACL,MAAM,KAAK,GAAG,6DAA6D,CAAC;QAE5E,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;YAC5C,OAAO,OAAO,CAAC,gBAAgB,EAAE,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,OAAO;YACL,KAAK;YACL,SAAS,EAAE;gBACT,QAAQ;aACT;SACF,CAAC;IACJ,CAAC;CACF"}
|