@taylordb/query-builder 0.9.0 → 0.9.2
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/__tests__/query-builder.spec.js +126 -23
- package/dist/cjs/__tests__/query-builder.spec.js.map +1 -1
- 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/executor.d.ts +4 -1
- package/dist/cjs/executor.js +20 -35
- package/dist/cjs/executor.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 +224 -5
- package/dist/cjs/query-builder.js +219 -5
- 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/{subscription-manager.d.ts → socket-connection.d.ts} +5 -4
- package/dist/cjs/{subscription-manager.js → socket-connection.js} +55 -9
- package/dist/cjs/socket-connection.js.map +1 -0
- 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/cjs/with-resolver.d.ts +5 -0
- package/dist/cjs/with-resolver.js +17 -0
- package/dist/cjs/with-resolver.js.map +1 -0
- package/dist/esm/__tests__/query-builder.spec.js +126 -23
- package/dist/esm/__tests__/query-builder.spec.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/executor.d.ts +4 -1
- package/dist/esm/executor.js +20 -35
- package/dist/esm/executor.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 +224 -5
- package/dist/esm/query-builder.js +217 -4
- 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/{subscription-manager.d.ts → socket-connection.d.ts} +5 -4
- package/dist/esm/{subscription-manager.js → socket-connection.js} +53 -7
- package/dist/esm/socket-connection.js.map +1 -0
- 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/esm/with-resolver.d.ts +5 -0
- package/dist/esm/with-resolver.js +14 -0
- package/dist/esm/with-resolver.js.map +1 -0
- package/dist/tsconfig.esm.tsbuildinfo +1 -1
- package/package.json +4 -2
- package/dist/cjs/subscription-manager.js.map +0 -1
- package/dist/esm/subscription-manager.js.map +0 -1
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2024 TaylorDB
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
CHANGED
|
@@ -111,3 +111,45 @@ const aggregates = await qb
|
|
|
111
111
|
})
|
|
112
112
|
.execute();
|
|
113
113
|
```
|
|
114
|
+
|
|
115
|
+
## Recipes
|
|
116
|
+
|
|
117
|
+
### Select with Relations
|
|
118
|
+
|
|
119
|
+
You can use the `with` method to fetch related records from a linked table.
|
|
120
|
+
|
|
121
|
+
```typescript
|
|
122
|
+
// Assuming 'customers' has a link field 'orders' to the 'orders' table
|
|
123
|
+
const customersWithOrders = await qb
|
|
124
|
+
.selectFrom('customers')
|
|
125
|
+
.select(['firstName', 'lastName'])
|
|
126
|
+
.with({
|
|
127
|
+
orders: qb => qb.select(['orderDate', 'total']),
|
|
128
|
+
})
|
|
129
|
+
.execute();
|
|
130
|
+
```
|
|
131
|
+
|
|
132
|
+
### Cross-Filters
|
|
133
|
+
|
|
134
|
+
You can filter records in one table based on the values in a linked table.
|
|
135
|
+
|
|
136
|
+
```typescript
|
|
137
|
+
// Get all customers who have placed an order with a total greater than 100
|
|
138
|
+
const highValueCustomers = await qb
|
|
139
|
+
.selectFrom('customers')
|
|
140
|
+
.where('orders', 'hasAnyOf', qb => qb.where('total', '>', 100))
|
|
141
|
+
.execute();
|
|
142
|
+
```
|
|
143
|
+
|
|
144
|
+
### Conditional Updates
|
|
145
|
+
|
|
146
|
+
You can use `where` clauses to update only the records that match a specific condition.
|
|
147
|
+
|
|
148
|
+
```typescript
|
|
149
|
+
// Update the status of all orders placed before a certain date
|
|
150
|
+
const { affectedRecords } = await qb
|
|
151
|
+
.update('orders')
|
|
152
|
+
.set({ status: 'archived' })
|
|
153
|
+
.where('orderDate', '<', '2023-01-01')
|
|
154
|
+
.execute();
|
|
155
|
+
```
|
|
@@ -1,20 +1,38 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const index_js_1 = require("../index.js");
|
|
4
|
+
const socket_connection_js_1 = require("../socket-connection.js");
|
|
5
|
+
jest.mock('socket.io-client', () => {
|
|
6
|
+
const mockSocket = {
|
|
7
|
+
on: jest.fn(),
|
|
8
|
+
emit: jest.fn(),
|
|
9
|
+
once: jest.fn(),
|
|
10
|
+
};
|
|
11
|
+
return {
|
|
12
|
+
io: jest.fn(() => mockSocket),
|
|
13
|
+
};
|
|
14
|
+
});
|
|
4
15
|
describe('QueryBuilder', () => {
|
|
16
|
+
let mockRawRequest;
|
|
17
|
+
beforeEach(() => {
|
|
18
|
+
mockRawRequest = jest.fn().mockResolvedValue({ execute: [] });
|
|
19
|
+
socket_connection_js_1.SocketConnection.prototype.rawRequest = mockRawRequest;
|
|
20
|
+
});
|
|
5
21
|
// @ts-ignore
|
|
6
22
|
const qb = (0, index_js_1.createQueryBuilder)({
|
|
7
23
|
baseUrl: 'http://localhost',
|
|
8
24
|
apiKey: 'test',
|
|
9
25
|
});
|
|
10
|
-
it('should compile a select query', () => {
|
|
11
|
-
|
|
26
|
+
it('should compile a select query and execute', async () => {
|
|
27
|
+
await qb
|
|
12
28
|
.selectFrom('customers')
|
|
13
29
|
.select(['firstName', 'lastName'])
|
|
14
30
|
.where('firstName', '=', 'John')
|
|
15
31
|
.orderBy('lastName', 'asc')
|
|
16
32
|
.paginate(1, 10)
|
|
17
|
-
.
|
|
33
|
+
.execute();
|
|
34
|
+
expect(mockRawRequest).toHaveBeenCalledTimes(1);
|
|
35
|
+
const variables = mockRawRequest.mock.calls[0][1];
|
|
18
36
|
expect(variables.metadata[0]).toMatchObject({
|
|
19
37
|
type: 'select',
|
|
20
38
|
tableName: 'customers',
|
|
@@ -33,26 +51,30 @@ describe('QueryBuilder', () => {
|
|
|
33
51
|
pagination: { offset: 0, limit: 10 },
|
|
34
52
|
});
|
|
35
53
|
});
|
|
36
|
-
it('should compile an insert query', () => {
|
|
37
|
-
|
|
54
|
+
it('should compile an insert query and execute', async () => {
|
|
55
|
+
await qb
|
|
38
56
|
.insertInto('customers')
|
|
39
57
|
.values({
|
|
40
58
|
firstName: 'Jane',
|
|
41
59
|
lastName: 'Doe',
|
|
42
60
|
})
|
|
43
|
-
.
|
|
61
|
+
.execute();
|
|
62
|
+
expect(mockRawRequest).toHaveBeenCalledTimes(1);
|
|
63
|
+
const variables = mockRawRequest.mock.calls[0][1];
|
|
44
64
|
expect(variables.metadata[0]).toMatchObject({
|
|
45
65
|
type: 'create',
|
|
46
66
|
tableName: 'customers',
|
|
47
67
|
createdRecords: [{ firstName: 'Jane', lastName: 'Doe' }],
|
|
48
68
|
});
|
|
49
69
|
});
|
|
50
|
-
it('should compile an update query', () => {
|
|
51
|
-
|
|
70
|
+
it('should compile an update query and execute', async () => {
|
|
71
|
+
await qb
|
|
52
72
|
.update('customers')
|
|
53
73
|
.set({ lastName: 'Smith' })
|
|
54
74
|
.where('id', '=', 1)
|
|
55
|
-
.
|
|
75
|
+
.execute();
|
|
76
|
+
expect(mockRawRequest).toHaveBeenCalledTimes(1);
|
|
77
|
+
const variables = mockRawRequest.mock.calls[0][1];
|
|
56
78
|
expect(variables.metadata[0]).toMatchObject({
|
|
57
79
|
type: 'update',
|
|
58
80
|
tableName: 'customers',
|
|
@@ -69,11 +91,10 @@ describe('QueryBuilder', () => {
|
|
|
69
91
|
},
|
|
70
92
|
});
|
|
71
93
|
});
|
|
72
|
-
it('should compile a delete query', () => {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
.compile();
|
|
94
|
+
it('should compile a delete query and execute', async () => {
|
|
95
|
+
await qb.deleteFrom('customers').where('id', '=', 1).execute();
|
|
96
|
+
expect(mockRawRequest).toHaveBeenCalledTimes(1);
|
|
97
|
+
const variables = mockRawRequest.mock.calls[0][1];
|
|
77
98
|
expect(variables.metadata[0]).toMatchObject({
|
|
78
99
|
type: 'delete',
|
|
79
100
|
tableName: 'customers',
|
|
@@ -89,15 +110,17 @@ describe('QueryBuilder', () => {
|
|
|
89
110
|
},
|
|
90
111
|
});
|
|
91
112
|
});
|
|
92
|
-
it('should compile a batch query', async () => {
|
|
93
|
-
|
|
113
|
+
it('should compile a batch query and execute', async () => {
|
|
114
|
+
await qb
|
|
94
115
|
.batch([
|
|
95
116
|
qb.selectFrom('customers').select(['firstName', 'lastName']),
|
|
96
117
|
qb
|
|
97
118
|
.insertInto('customers')
|
|
98
119
|
.values({ firstName: 'John', lastName: 'Doe' }),
|
|
99
120
|
])
|
|
100
|
-
.
|
|
121
|
+
.execute();
|
|
122
|
+
expect(mockRawRequest).toHaveBeenCalledTimes(1);
|
|
123
|
+
const variables = mockRawRequest.mock.calls[0][1];
|
|
101
124
|
expect(variables.metadata).toHaveLength(2);
|
|
102
125
|
expect(variables.metadata[0]).toMatchObject({
|
|
103
126
|
type: 'select',
|
|
@@ -108,14 +131,16 @@ describe('QueryBuilder', () => {
|
|
|
108
131
|
tableName: 'customers',
|
|
109
132
|
});
|
|
110
133
|
});
|
|
111
|
-
it('should compile an aggregate query', () => {
|
|
112
|
-
|
|
134
|
+
it('should compile an aggregate query and execute', async () => {
|
|
135
|
+
await qb
|
|
113
136
|
.aggregateFrom('customers')
|
|
114
137
|
.groupBy('firstName', 'asc')
|
|
115
138
|
.withAggregates({
|
|
116
139
|
id: ['sum'],
|
|
117
140
|
})
|
|
118
|
-
.
|
|
141
|
+
.execute();
|
|
142
|
+
expect(mockRawRequest).toHaveBeenCalledTimes(1);
|
|
143
|
+
const variables = mockRawRequest.mock.calls[0][1];
|
|
119
144
|
expect(variables.metadata[0]).toMatchObject({
|
|
120
145
|
type: 'aggregation',
|
|
121
146
|
tableName: 'customers',
|
|
@@ -125,11 +150,13 @@ describe('QueryBuilder', () => {
|
|
|
125
150
|
},
|
|
126
151
|
});
|
|
127
152
|
});
|
|
128
|
-
it('should compile a cross-table query', () => {
|
|
129
|
-
|
|
153
|
+
it('should compile a cross-table query and execute', async () => {
|
|
154
|
+
await qb
|
|
130
155
|
.selectFrom('customers')
|
|
131
156
|
.where('orders', 'hasAnyOf', qb => qb.where('amount', '>', 100))
|
|
132
|
-
.
|
|
157
|
+
.execute();
|
|
158
|
+
expect(mockRawRequest).toHaveBeenCalledTimes(1);
|
|
159
|
+
const variables = mockRawRequest.mock.calls[0][1];
|
|
133
160
|
expect(variables.metadata[0]).toMatchObject({
|
|
134
161
|
type: 'select',
|
|
135
162
|
tableName: 'customers',
|
|
@@ -157,5 +184,81 @@ describe('QueryBuilder', () => {
|
|
|
157
184
|
},
|
|
158
185
|
});
|
|
159
186
|
});
|
|
187
|
+
it('should handle a successful transaction', async () => {
|
|
188
|
+
const mockRawRequest = jest
|
|
189
|
+
.fn()
|
|
190
|
+
.mockResolvedValueOnce({
|
|
191
|
+
startTransaction: 'test-transaction-id',
|
|
192
|
+
})
|
|
193
|
+
.mockResolvedValueOnce({ execute: [] })
|
|
194
|
+
.mockResolvedValueOnce({ commitTransaction: true });
|
|
195
|
+
socket_connection_js_1.SocketConnection.prototype.rawRequest = mockRawRequest;
|
|
196
|
+
// @ts-ignore
|
|
197
|
+
const qb = (0, index_js_1.createQueryBuilder)({
|
|
198
|
+
baseUrl: 'http://localhost',
|
|
199
|
+
apiKey: 'test',
|
|
200
|
+
});
|
|
201
|
+
await qb.transaction(txQb => {
|
|
202
|
+
return txQb
|
|
203
|
+
.insertInto('customers')
|
|
204
|
+
.values({ firstName: 'John', lastName: 'Doe' })
|
|
205
|
+
.execute();
|
|
206
|
+
});
|
|
207
|
+
expect(mockRawRequest).toHaveBeenCalledTimes(3);
|
|
208
|
+
const startTransactionCall = mockRawRequest.mock.calls[0];
|
|
209
|
+
expect(startTransactionCall[0]).toContain('startTransaction');
|
|
210
|
+
const executeCall = mockRawRequest.mock.calls[1];
|
|
211
|
+
expect(executeCall[3]).toBe('test-transaction-id');
|
|
212
|
+
const commitTransactionCall = mockRawRequest.mock.calls[2];
|
|
213
|
+
expect(commitTransactionCall[0]).toContain('commitTransaction');
|
|
214
|
+
expect(commitTransactionCall[3]).toBe('test-transaction-id');
|
|
215
|
+
});
|
|
216
|
+
it('should handle a failed transaction and rollback', async () => {
|
|
217
|
+
const transactionId = 'test-transaction-id-fail';
|
|
218
|
+
const errorMessage = 'Something went wrong';
|
|
219
|
+
const mockRawRequest = jest
|
|
220
|
+
.fn()
|
|
221
|
+
.mockResolvedValueOnce({ startTransaction: transactionId })
|
|
222
|
+
.mockRejectedValueOnce(new Error(errorMessage))
|
|
223
|
+
.mockResolvedValueOnce({ rollbackTransaction: true });
|
|
224
|
+
socket_connection_js_1.SocketConnection.prototype.rawRequest = mockRawRequest;
|
|
225
|
+
// @ts-ignore
|
|
226
|
+
const qb = (0, index_js_1.createQueryBuilder)({
|
|
227
|
+
baseUrl: 'http://localhost',
|
|
228
|
+
apiKey: 'test',
|
|
229
|
+
});
|
|
230
|
+
await expect(qb.transaction(txQb => {
|
|
231
|
+
return txQb
|
|
232
|
+
.insertInto('customers')
|
|
233
|
+
.values({ firstName: 'John', lastName: 'Doe' })
|
|
234
|
+
.execute();
|
|
235
|
+
})).rejects.toThrow(errorMessage);
|
|
236
|
+
expect(mockRawRequest).toHaveBeenCalledTimes(3);
|
|
237
|
+
const startTransactionCall = mockRawRequest.mock.calls[0];
|
|
238
|
+
expect(startTransactionCall[0]).toContain('startTransaction');
|
|
239
|
+
const executeCall = mockRawRequest.mock.calls[1];
|
|
240
|
+
expect(executeCall[3]).toBe(transactionId);
|
|
241
|
+
const rollbackTransactionCall = mockRawRequest.mock.calls[2];
|
|
242
|
+
expect(rollbackTransactionCall[0]).toContain('rollbackTransaction');
|
|
243
|
+
expect(rollbackTransactionCall[3]).toBe(transactionId);
|
|
244
|
+
});
|
|
245
|
+
it('should not have transaction method within a transaction', async () => {
|
|
246
|
+
const mockRawRequest = jest
|
|
247
|
+
.fn()
|
|
248
|
+
.mockResolvedValueOnce({
|
|
249
|
+
startTransaction: 'test-transaction-id-no-nested',
|
|
250
|
+
})
|
|
251
|
+
.mockResolvedValueOnce({ commitTransaction: true });
|
|
252
|
+
socket_connection_js_1.SocketConnection.prototype.rawRequest = mockRawRequest;
|
|
253
|
+
// @ts-ignore
|
|
254
|
+
const qb = (0, index_js_1.createQueryBuilder)({
|
|
255
|
+
baseUrl: 'http://localhost',
|
|
256
|
+
apiKey: 'test',
|
|
257
|
+
});
|
|
258
|
+
await qb.transaction(async (txQb) => {
|
|
259
|
+
expect(txQb).not.toHaveProperty('transaction');
|
|
260
|
+
});
|
|
261
|
+
expect(mockRawRequest).toHaveBeenCalledTimes(2);
|
|
262
|
+
});
|
|
160
263
|
});
|
|
161
264
|
//# sourceMappingURL=query-builder.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"query-builder.spec.js","sourceRoot":"","sources":["../../../src/__tests__/query-builder.spec.ts"],"names":[],"mappings":";;AAAA,0CAAiD;
|
|
1
|
+
{"version":3,"file":"query-builder.spec.js","sourceRoot":"","sources":["../../../src/__tests__/query-builder.spec.ts"],"names":[],"mappings":";;AAAA,0CAAiD;AACjD,kEAA2D;AAgC3D,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,GAAG,EAAE;IACjC,MAAM,UAAU,GAAG;QACjB,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE;QACb,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE;QACf,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE;KAChB,CAAC;IACF,OAAO;QACL,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC;KAC9B,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,IAAI,cAAyB,CAAC;IAE9B,UAAU,CAAC,GAAG,EAAE;QACd,cAAc,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC;QAC9D,uCAAgB,CAAC,SAAS,CAAC,UAAU,GAAG,cAAc,CAAC;IACzD,CAAC,CAAC,CAAC;IAEH,aAAa;IACb,MAAM,EAAE,GAAG,IAAA,6BAAkB,EAAiB;QAC5C,OAAO,EAAE,kBAAkB;QAC3B,MAAM,EAAE,MAAM;KACf,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;QACzD,MAAM,EAAE;aACL,UAAU,CAAC,WAAW,CAAC;aACvB,MAAM,CAAC,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;aACjC,KAAK,CAAC,WAAW,EAAE,GAAG,EAAE,MAAM,CAAC;aAC/B,OAAO,CAAC,UAAU,EAAE,KAAK,CAAC;aAC1B,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC;aACf,OAAO,EAAE,CAAC;QAEb,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,SAAS,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAC1C,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,WAAW;YACtB,MAAM,EAAE,CAAC,WAAW,EAAE,UAAU,CAAC;YACjC,UAAU,EAAE;gBACV,WAAW,EAAE,KAAK;gBAClB,UAAU,EAAE;oBACV;wBACE,KAAK,EAAE,WAAW;wBAClB,QAAQ,EAAE,GAAG;wBACb,KAAK,EAAE,MAAM;qBACd;iBACF;aACF;YACD,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;YAClD,UAAU,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE;SACrC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,EAAE;aACL,UAAU,CAAC,WAAW,CAAC;aACvB,MAAM,CAAC;YACN,SAAS,EAAE,MAAM;YACjB,QAAQ,EAAE,KAAK;SAChB,CAAC;aACD,OAAO,EAAE,CAAC;QAEb,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,SAAS,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAC1C,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,WAAW;YACtB,cAAc,EAAE,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;SACzD,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,EAAE;aACL,MAAM,CAAC,WAAW,CAAC;aACnB,GAAG,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC;aAC1B,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;aACnB,OAAO,EAAE,CAAC;QAEb,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,SAAS,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAC1C,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,WAAW;YACtB,MAAM,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE;YAC7B,UAAU,EAAE;gBACV,WAAW,EAAE,KAAK;gBAClB,UAAU,EAAE;oBACV;wBACE,KAAK,EAAE,IAAI;wBACX,QAAQ,EAAE,GAAG;wBACb,KAAK,EAAE,CAAC;qBACT;iBACF;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;QACzD,MAAM,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;QAE/D,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,SAAS,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAC1C,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,WAAW;YACtB,UAAU,EAAE;gBACV,WAAW,EAAE,KAAK;gBAClB,UAAU,EAAE;oBACV;wBACE,KAAK,EAAE,IAAI;wBACX,QAAQ,EAAE,GAAG;wBACb,KAAK,EAAE,CAAC;qBACT;iBACF;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE,KAAK,IAAI,EAAE;QACxD,MAAM,EAAE;aACL,KAAK,CAAC;YACL,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;YAC5D,EAAE;iBACC,UAAU,CAAC,WAAW,CAAC;iBACvB,MAAM,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;SAClD,CAAC;aACD,OAAO,EAAE,CAAC;QAEb,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,SAAS,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC3C,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAC1C,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,WAAW;SACvB,CAAC,CAAC;QACH,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAC1C,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,WAAW;SACvB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,MAAM,EAAE;aACL,aAAa,CAAC,WAAW,CAAC;aAC1B,OAAO,CAAC,WAAW,EAAE,KAAK,CAAC;aAC3B,cAAc,CAAC;YACd,EAAE,EAAE,CAAC,KAAK,CAAC;SACZ,CAAC;aACD,OAAO,EAAE,CAAC;QAEb,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,SAAS,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAC1C,IAAI,EAAE,aAAa;YACnB,SAAS,EAAE,WAAW;YACtB,SAAS,EAAE,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;YACrD,YAAY,EAAE;gBACZ,EAAE,EAAE,CAAC,KAAK,CAAC;aACZ;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,KAAK,IAAI,EAAE;QAC9D,MAAM,EAAE;aACL,UAAU,CAAC,WAAW,CAAC;aACvB,KAAK,CAAC,QAAQ,EAAE,UAAU,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;aAC/D,OAAO,EAAE,CAAC;QAEb,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,SAAS,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAC1C,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,WAAW;YACtB,UAAU,EAAE;gBACV,WAAW,EAAE,KAAK;gBAClB,UAAU,EAAE;oBACV;wBACE,KAAK,EAAE,QAAQ;wBACf,QAAQ,EAAE,UAAU;wBACpB,KAAK,EAAE;4BACL,aAAa;4BACb;gCACE,WAAW,EAAE,KAAK;gCAClB,UAAU,EAAE;oCACV;wCACE,KAAK,EAAE,QAAQ;wCACf,QAAQ,EAAE,GAAG;wCACb,KAAK,EAAE,GAAG;qCACX;iCACF;6BACF;yBACF;qBACF;iBACF;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,MAAM,cAAc,GAAG,IAAI;aACxB,EAAE,EAAE;aACJ,qBAAqB,CAAC;YACrB,gBAAgB,EAAE,qBAAqB;SACxC,CAAC;aACD,qBAAqB,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;aACtC,qBAAqB,CAAC,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,CAAC;QAEtD,uCAAgB,CAAC,SAAS,CAAC,UAAU,GAAG,cAAc,CAAC;QAEvD,aAAa;QACb,MAAM,EAAE,GAAG,IAAA,6BAAkB,EAAiB;YAC5C,OAAO,EAAE,kBAAkB;YAC3B,MAAM,EAAE,MAAM;SACf,CAAC,CAAC;QAEH,MAAM,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;YAC1B,OAAO,IAAI;iBACR,UAAU,CAAC,WAAW,CAAC;iBACvB,MAAM,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;iBAC9C,OAAO,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAEhD,MAAM,oBAAoB,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1D,MAAM,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;QAE9D,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACjD,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAEnD,MAAM,qBAAqB,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC3D,MAAM,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC;QAChE,MAAM,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,aAAa,GAAG,0BAA0B,CAAC;QACjD,MAAM,YAAY,GAAG,sBAAsB,CAAC;QAE5C,MAAM,cAAc,GAAG,IAAI;aACxB,EAAE,EAAE;aACJ,qBAAqB,CAAC,EAAE,gBAAgB,EAAE,aAAa,EAAE,CAAC;aAC1D,qBAAqB,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC;aAC9C,qBAAqB,CAAC,EAAE,mBAAmB,EAAE,IAAI,EAAE,CAAC,CAAC;QAExD,uCAAgB,CAAC,SAAS,CAAC,UAAU,GAAG,cAAc,CAAC;QAEvD,aAAa;QACb,MAAM,EAAE,GAAG,IAAA,6BAAkB,EAAiB;YAC5C,OAAO,EAAE,kBAAkB;YAC3B,MAAM,EAAE,MAAM;SACf,CAAC,CAAC;QAEH,MAAM,MAAM,CACV,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;YACpB,OAAO,IAAI;iBACR,UAAU,CAAC,WAAW,CAAC;iBACvB,MAAM,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;iBAC9C,OAAO,EAAE,CAAC;QACf,CAAC,CAAC,CACH,CAAC,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QAEhC,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAEhD,MAAM,oBAAoB,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1D,MAAM,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;QAE9D,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACjD,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAE3C,MAAM,uBAAuB,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC7D,MAAM,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,qBAAqB,CAAC,CAAC;QACpE,MAAM,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;QACvE,MAAM,cAAc,GAAG,IAAI;aACxB,EAAE,EAAE;aACJ,qBAAqB,CAAC;YACrB,gBAAgB,EAAE,+BAA+B;SAClD,CAAC;aACD,qBAAqB,CAAC,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,CAAC;QAEtD,uCAAgB,CAAC,SAAS,CAAC,UAAU,GAAG,cAAc,CAAC;QAEvD,aAAa;QACb,MAAM,EAAE,GAAG,IAAA,6BAAkB,EAAiB;YAC5C,OAAO,EAAE,kBAAkB;YAC3B,MAAM,EAAE,MAAM;SACf,CAAC,CAAC;QAEH,MAAM,EAAE,CAAC,WAAW,CAAC,KAAK,EAAC,IAAI,EAAC,EAAE;YAChC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -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
|
}>;
|
|
@@ -2,12 +2,34 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.AggregationQueryBuilder = void 0;
|
|
4
4
|
const where_query_builder_js_1 = require("./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
|
class AggregationQueryBuilder extends where_query_builder_js_1.FilterableQueryBuilder {
|
|
6
13
|
#node;
|
|
7
14
|
constructor(node, executor) {
|
|
8
15
|
super(node, executor);
|
|
9
16
|
this.#node = node;
|
|
10
17
|
}
|
|
18
|
+
/**
|
|
19
|
+
* Groups the results by a specified field.
|
|
20
|
+
* @param field - The field to group by.
|
|
21
|
+
* @param direction - The sort direction for the grouping.
|
|
22
|
+
* @returns A new `AggregationQueryBuilder` instance with the grouping applied.
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* ```typescript
|
|
26
|
+
* const userCounts = await qb
|
|
27
|
+
* .aggregateFrom('users')
|
|
28
|
+
* .groupBy('role')
|
|
29
|
+
* .withAggregates({ id: ['count'] })
|
|
30
|
+
* .execute();
|
|
31
|
+
* ```
|
|
32
|
+
*/
|
|
11
33
|
groupBy(field, direction = 'asc') {
|
|
12
34
|
const newGrouping = {
|
|
13
35
|
field,
|
|
@@ -18,6 +40,22 @@ class AggregationQueryBuilder extends where_query_builder_js_1.FilterableQueryBu
|
|
|
18
40
|
groupings: [...(this.#node.groupings || []), newGrouping],
|
|
19
41
|
}, this._executor);
|
|
20
42
|
}
|
|
43
|
+
/**
|
|
44
|
+
* Specifies the aggregations to perform.
|
|
45
|
+
* @param aggregates - An object where the keys are field names and the values are arrays of aggregation functions.
|
|
46
|
+
* @returns A new `AggregationQueryBuilder` instance with the aggregations applied.
|
|
47
|
+
*
|
|
48
|
+
* @example
|
|
49
|
+
* ```typescript
|
|
50
|
+
* const userStats = await qb
|
|
51
|
+
* .aggregateFrom('users')
|
|
52
|
+
* .withAggregates({
|
|
53
|
+
* id: ['count'],
|
|
54
|
+
* age: ['avg', 'sum'],
|
|
55
|
+
* })
|
|
56
|
+
* .execute();
|
|
57
|
+
* ```
|
|
58
|
+
*/
|
|
21
59
|
withAggregates(aggregates) {
|
|
22
60
|
const newAggregates = { ...this.#node.aggregations };
|
|
23
61
|
for (const key in aggregates) {
|
|
@@ -28,21 +66,43 @@ class AggregationQueryBuilder extends where_query_builder_js_1.FilterableQueryBu
|
|
|
28
66
|
aggregations: newAggregates,
|
|
29
67
|
}, this._executor);
|
|
30
68
|
}
|
|
69
|
+
/**
|
|
70
|
+
* Sets the maximum number of records to return.
|
|
71
|
+
* @param count - The maximum number of records.
|
|
72
|
+
* @returns A new `AggregationQueryBuilder` instance with the limit applied.
|
|
73
|
+
*/
|
|
31
74
|
limit(count) {
|
|
32
75
|
return new AggregationQueryBuilder({
|
|
33
76
|
...this.#node,
|
|
34
77
|
pagination: { ...this.#node.pagination, limit: count },
|
|
35
78
|
}, this._executor);
|
|
36
79
|
}
|
|
80
|
+
/**
|
|
81
|
+
* Sets the number of records to skip.
|
|
82
|
+
* @param count - The number of records to skip.
|
|
83
|
+
* @returns A new `AggregationQueryBuilder` instance with the offset applied.
|
|
84
|
+
*/
|
|
37
85
|
offset(count) {
|
|
38
86
|
return new AggregationQueryBuilder({
|
|
39
87
|
...this.#node,
|
|
40
88
|
pagination: { ...this.#node.pagination, offset: count },
|
|
41
89
|
}, this._executor);
|
|
42
90
|
}
|
|
91
|
+
/**
|
|
92
|
+
* Paginates the results.
|
|
93
|
+
* @param page - The page number to retrieve.
|
|
94
|
+
* @param limit - The number of records per page.
|
|
95
|
+
* @returns A new `AggregationQueryBuilder` instance with pagination applied.
|
|
96
|
+
*/
|
|
43
97
|
paginate(page, limit) {
|
|
44
98
|
return this.offset((page - 1) * limit).limit(limit);
|
|
45
99
|
}
|
|
100
|
+
/**
|
|
101
|
+
* Sorts the results by a specified field.
|
|
102
|
+
* @param field - The field to sort by.
|
|
103
|
+
* @param direction - The sort direction ('asc' or 'desc').
|
|
104
|
+
* @returns A new `AggregationQueryBuilder` instance with the sorting applied.
|
|
105
|
+
*/
|
|
46
106
|
orderBy(field, direction = 'asc') {
|
|
47
107
|
const newSorting = {
|
|
48
108
|
field: field,
|
|
@@ -53,10 +113,42 @@ class AggregationQueryBuilder extends where_query_builder_js_1.FilterableQueryBu
|
|
|
53
113
|
sorting: [...(this.#node.sorting || []), newSorting],
|
|
54
114
|
}, this._executor);
|
|
55
115
|
}
|
|
116
|
+
/**
|
|
117
|
+
* Executes the aggregation query.
|
|
118
|
+
* @returns A promise that resolves with an array of the aggregation results.
|
|
119
|
+
*
|
|
120
|
+
* @example
|
|
121
|
+
* ```typescript
|
|
122
|
+
* const userCounts = await qb
|
|
123
|
+
* .aggregateFrom('users')
|
|
124
|
+
* .groupBy('role')
|
|
125
|
+
* .withAggregates({ id: ['count'] })
|
|
126
|
+
* .execute();
|
|
127
|
+
* ```
|
|
128
|
+
*/
|
|
56
129
|
async execute() {
|
|
57
130
|
const response = await this._executor.execute(this);
|
|
58
131
|
return response;
|
|
59
132
|
}
|
|
133
|
+
/**
|
|
134
|
+
* Subscribes to the results of the aggregation query.
|
|
135
|
+
* @param callback - A callback function that will be called with the results of the aggregation query.
|
|
136
|
+
* @returns A function to unsubscribe from the query.
|
|
137
|
+
*
|
|
138
|
+
* @example
|
|
139
|
+
* ```typescript
|
|
140
|
+
* const unsubscribe = qb
|
|
141
|
+
* .aggregateFrom('users')
|
|
142
|
+
* .groupBy('role')
|
|
143
|
+
* .withAggregates({ id: ['count'] })
|
|
144
|
+
* .subscribe((userCounts) => {
|
|
145
|
+
* console.log('User counts by role:', userCounts);
|
|
146
|
+
* });
|
|
147
|
+
*
|
|
148
|
+
* // To stop listening for updates
|
|
149
|
+
* unsubscribe();
|
|
150
|
+
* ```
|
|
151
|
+
*/
|
|
60
152
|
subscribe(callback) {
|
|
61
153
|
return this._executor.subscribe([this], callback);
|
|
62
154
|
}
|
|
@@ -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":"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"}
|
|
@@ -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<{
|