@taylordb/query-builder 0.8.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.
Files changed (70) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +42 -0
  3. package/dist/cjs/@types/insert.d.ts +13 -4
  4. package/dist/cjs/@types/query-builder.d.ts +2 -2
  5. package/dist/cjs/@types/type-helpers.d.ts +3 -3
  6. package/dist/cjs/@types/update.d.ts +8 -3
  7. package/dist/cjs/__tests__/query-builder.spec.js +1 -1
  8. package/dist/cjs/__tests__/query-builder.spec.js.map +1 -1
  9. package/dist/cjs/__tests__/taylorclient.types.d.ts +57 -51
  10. package/dist/cjs/aggregation-query-builder.d.ts +92 -0
  11. package/dist/cjs/aggregation-query-builder.js +92 -0
  12. package/dist/cjs/aggregation-query-builder.js.map +1 -1
  13. package/dist/cjs/batch-query-builder.d.ts +36 -0
  14. package/dist/cjs/batch-query-builder.js +36 -0
  15. package/dist/cjs/batch-query-builder.js.map +1 -1
  16. package/dist/cjs/delete-query-builder.d.ts +17 -0
  17. package/dist/cjs/delete-query-builder.js +17 -0
  18. package/dist/cjs/delete-query-builder.js.map +1 -1
  19. package/dist/cjs/executor.js +1 -1
  20. package/dist/cjs/executor.js.map +1 -1
  21. package/dist/cjs/insert-query-builder.d.ts +68 -0
  22. package/dist/cjs/insert-query-builder.js +71 -0
  23. package/dist/cjs/insert-query-builder.js.map +1 -1
  24. package/dist/cjs/query-builder.d.ts +218 -1
  25. package/dist/cjs/query-builder.js +188 -0
  26. package/dist/cjs/query-builder.js.map +1 -1
  27. package/dist/cjs/selection-builder.d.ts +12 -1
  28. package/dist/cjs/selection-builder.js +11 -0
  29. package/dist/cjs/selection-builder.js.map +1 -1
  30. package/dist/cjs/update-query-builder.d.ts +32 -0
  31. package/dist/cjs/update-query-builder.js +32 -0
  32. package/dist/cjs/update-query-builder.js.map +1 -1
  33. package/dist/cjs/where-query-builder.d.ts +61 -2
  34. package/dist/cjs/where-query-builder.js +6 -0
  35. package/dist/cjs/where-query-builder.js.map +1 -1
  36. package/dist/esm/@types/insert.d.ts +13 -4
  37. package/dist/esm/@types/query-builder.d.ts +2 -2
  38. package/dist/esm/@types/type-helpers.d.ts +3 -3
  39. package/dist/esm/@types/update.d.ts +8 -3
  40. package/dist/esm/__tests__/query-builder.spec.js +1 -1
  41. package/dist/esm/__tests__/query-builder.spec.js.map +1 -1
  42. package/dist/esm/__tests__/taylorclient.types.d.ts +57 -51
  43. package/dist/esm/aggregation-query-builder.d.ts +92 -0
  44. package/dist/esm/aggregation-query-builder.js +92 -0
  45. package/dist/esm/aggregation-query-builder.js.map +1 -1
  46. package/dist/esm/batch-query-builder.d.ts +36 -0
  47. package/dist/esm/batch-query-builder.js +36 -0
  48. package/dist/esm/batch-query-builder.js.map +1 -1
  49. package/dist/esm/delete-query-builder.d.ts +17 -0
  50. package/dist/esm/delete-query-builder.js +17 -0
  51. package/dist/esm/delete-query-builder.js.map +1 -1
  52. package/dist/esm/executor.js +1 -1
  53. package/dist/esm/executor.js.map +1 -1
  54. package/dist/esm/insert-query-builder.d.ts +68 -0
  55. package/dist/esm/insert-query-builder.js +71 -0
  56. package/dist/esm/insert-query-builder.js.map +1 -1
  57. package/dist/esm/query-builder.d.ts +218 -1
  58. package/dist/esm/query-builder.js +188 -0
  59. package/dist/esm/query-builder.js.map +1 -1
  60. package/dist/esm/selection-builder.d.ts +12 -1
  61. package/dist/esm/selection-builder.js +11 -0
  62. package/dist/esm/selection-builder.js.map +1 -1
  63. package/dist/esm/update-query-builder.d.ts +32 -0
  64. package/dist/esm/update-query-builder.js +32 -0
  65. package/dist/esm/update-query-builder.js.map +1 -1
  66. package/dist/esm/where-query-builder.d.ts +61 -2
  67. package/dist/esm/where-query-builder.js +6 -0
  68. package/dist/esm/where-query-builder.js.map +1 -1
  69. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  70. package/package.json +3 -3
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,8 +1,17 @@
1
- import { ColumnType, CreateMutationMetaData, MetadataWithTableName } from '@taylordb/shared';
2
- import { QueryNode } from './internal-types.js';
1
+ import { CreateMutationMetaData, MetadataWithTableName } from '@taylordb/shared';
2
+ import { AnyDB, QueryNode } from './internal-types.js';
3
3
  export type InsertNode = MetadataWithTableName<CreateMutationMetaData> & {
4
4
  returning: (string | QueryNode)[];
5
5
  };
6
- export type Insertable<T> = {
7
- [K in keyof T]?: T[K] extends ColumnType<any, any, infer I, any> ? I : never;
6
+ type RequiredKeys<T extends AnyDB[string]> = {
7
+ [K in keyof T]: T[K]['isRequired'] extends true ? T[K]['insert'] extends never ? never : K : never;
8
+ }[keyof T];
9
+ type OptionalKeys<T extends AnyDB[string]> = {
10
+ [K in keyof T]: T[K]['isRequired'] extends false ? T[K]['insert'] extends never ? never : K : never;
11
+ }[keyof T];
12
+ export type Insertable<T extends AnyDB[string]> = {
13
+ [K in RequiredKeys<T>]: T[K]['insert'];
14
+ } & {
15
+ [K in OptionalKeys<T>]?: T[K]['insert'];
8
16
  };
17
+ export {};
@@ -1,8 +1,8 @@
1
1
  import { LinkColumnType } from '@taylordb/shared';
2
2
  export type NonLinkColumnNames<T> = {
3
- [K in keyof T]: T[K] extends LinkColumnType<any> ? never : K;
3
+ [K in keyof T]: T[K] extends LinkColumnType<any, any> ? never : K;
4
4
  }[keyof T];
5
5
  export type LinkColumnNames<T> = {
6
- [K in keyof T]: T[K] extends LinkColumnType<any> ? K : never;
6
+ [K in keyof T]: T[K] extends LinkColumnType<any, any> ? K : never;
7
7
  }[keyof T];
8
8
  export type ColumnNames<T> = keyof T;
@@ -2,8 +2,8 @@ import { ColumnType, LinkColumnType } from '@taylordb/shared';
2
2
  import { QueryBuilder } from '../query-builder.js';
3
3
  import { AnyDB } from './internal-types.js';
4
4
  import { LinkColumnNames, NonLinkColumnNames } from './query-builder.js';
5
- export type InferDataType<TColumn> = TColumn extends ColumnType<infer D, any, any, any> ? D : never;
6
- export type TableShape<TTable> = {
5
+ export type InferDataType<TColumn extends ColumnType<any, any, any, any, any>> = TColumn['isRequired'] extends true ? TColumn['raw'] : TColumn['raw'] | undefined;
6
+ export type TableShape<TTable extends AnyDB[string]> = {
7
7
  [K in keyof TTable]: InferDataType<TTable[K]>;
8
8
  };
9
9
  type InferSubqueryResult<TSubquery> = TSubquery extends QueryBuilder<any, any, infer TSelection, any> ? TSelection[] : never;
@@ -18,7 +18,7 @@ export type ResolveSelection<DB extends AnyDB, TName extends keyof DB, TFields e
18
18
  }[number]>;
19
19
  export type ResolveWithPlain<DB extends AnyDB, TName extends keyof DB, TRelations extends (LinkColumnNames<DB[TName]> & string) | readonly (LinkColumnNames<DB[TName]> & string)[], TCurrentSelection> = TCurrentSelection & UnionToIntersection<{
20
20
  [K in TRelations extends readonly any[] ? TRelations[number] : TRelations]: {
21
- [P in K]: TableShape<DB[DB[TName][P] extends LinkColumnType<infer L> ? L : never]>[];
21
+ [P in K]: TableShape<DB[DB[TName][P] extends LinkColumnType<infer L, any> ? L : never]>[];
22
22
  };
23
23
  }[TRelations extends readonly any[] ? TRelations[number] : TRelations]>;
24
24
  export type ResolveWithObject<TRelations extends Record<string, (qb: any) => QueryBuilder<any, any, any, any>>, TCurrentSelection> = TCurrentSelection & {
@@ -1,5 +1,10 @@
1
- import { ColumnType, MetadataWithTableName, UpdateMutationMetaData } from '@taylordb/shared';
1
+ import { MetadataWithTableName, UpdateMutationMetaData } from '@taylordb/shared';
2
+ import { AnyDB } from './internal-types';
2
3
  export type UpdateNode = MetadataWithTableName<UpdateMutationMetaData>;
3
- export type Updatable<T> = {
4
- [K in keyof T]?: T[K] extends ColumnType<any, any, infer I, any> ? I : never;
4
+ type NotUpdatableKeys<T extends AnyDB[string]> = {
5
+ [K in keyof T]: T[K]['update'] extends never ? K : never;
6
+ }[keyof T];
7
+ export type Updatable<T extends AnyDB[string]> = {
8
+ [K in keyof Omit<T, NotUpdatableKeys<T>>]?: T[K]['update'];
5
9
  };
10
+ export {};
@@ -89,7 +89,7 @@ describe('QueryBuilder', () => {
89
89
  },
90
90
  });
91
91
  });
92
- it('should compile a batch query', () => {
92
+ it('should compile a batch query', async () => {
93
93
  const { variables } = qb
94
94
  .batch([
95
95
  qb.selectFrom('customers').select(['firstName', 'lastName']),
@@ -1 +1 @@
1
- {"version":3,"file":"query-builder.spec.js","sourceRoot":"","sources":["../../../src/__tests__/query-builder.spec.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"query-builder.spec.js","sourceRoot":"","sources":["../../../src/__tests__/query-builder.spec.ts"],"names":[],"mappings":"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"}
@@ -6,19 +6,7 @@
6
6
  */
7
7
  type IsWithinOperatorValue = 'pastWeek' | 'pastMonth' | 'pastYear' | 'nextWeek' | 'nextMonth' | 'nextYear' | 'daysFromNow' | 'daysAgo' | 'currentWeek' | 'currentMonth' | 'currentYear';
8
8
  type DefaultDateFilterValue = ('today' | 'tomorrow' | 'yesterday' | 'oneWeekAgo' | 'oneWeekFromNow' | 'oneMonthAgo' | 'oneMonthFromNow') | ['exactDay' | 'exactTimestamp', string] | ['daysAgo' | 'daysFromNow', number];
9
- export type ColumnType<S, U, I, T, F extends {
10
- [key: string]: any;
11
- } = object, A extends {
12
- [key: string]: any;
13
- } = object> = {
14
- raw: S;
15
- insert: I;
16
- update: U;
17
- type: T;
18
- filters: F;
19
- aggregations: A;
20
- };
21
- export type DateColumnType = ColumnType<string | undefined, string | undefined, string | undefined, 'date', {
9
+ type DateFilters = {
22
10
  '=': DefaultDateFilterValue;
23
11
  '!=': DefaultDateFilterValue;
24
12
  '<': DefaultDateFilterValue;
@@ -31,7 +19,8 @@ export type DateColumnType = ColumnType<string | undefined, string | undefined,
31
19
  };
32
20
  isEmpty: boolean;
33
21
  isNotEmpty: boolean;
34
- }, {
22
+ };
23
+ type DateAggregations = {
35
24
  empty: number;
36
25
  filled: number;
37
26
  unique: number;
@@ -42,8 +31,8 @@ export type DateColumnType = ColumnType<string | undefined, string | undefined,
42
31
  max: number | null;
43
32
  daysRange: number | null;
44
33
  monthRange: number | null;
45
- }>;
46
- export type TextColumnType = ColumnType<string | undefined, string | undefined, string | null, 'text', {
34
+ };
35
+ type TextFilters = {
47
36
  '=': string;
48
37
  '!=': string;
49
38
  caseEqual: string;
@@ -52,34 +41,30 @@ export type TextColumnType = ColumnType<string | undefined, string | undefined,
52
41
  startsWith: string;
53
42
  endsWith: string;
54
43
  doesNotContain: string;
55
- }>;
56
- export type LinkColumnType<T extends string> = ColumnType<object, number[] | {
57
- newIds: number[];
58
- deletedIds: number[];
59
- } | undefined, number[] | undefined, 'link', {
44
+ };
45
+ type LinkFilters = {
60
46
  hasAnyOf: number[];
61
47
  hasAllOf: number[];
62
48
  isExactly: number[];
63
49
  '=': number;
64
50
  hasNoneOf: number[];
65
- }, {
51
+ };
52
+ type LinkAggregations = {
66
53
  empty: number;
67
54
  filled: number;
68
55
  percentEmpty: number;
69
56
  percentFilled: number;
70
- }> & {
71
- linkedTo: T;
72
57
  };
73
- export type NumberColumnType = ColumnType<number | undefined, number | undefined, number | undefined, 'number', {
58
+ type NumberFilters = {
74
59
  '=': number;
75
- '!=': number;
76
60
  '>': number;
77
61
  '>=': number;
78
62
  '<': number;
79
63
  '<=': number;
80
64
  hasAnyOf: number[];
81
65
  hasNoneOf: number[];
82
- }, {
66
+ };
67
+ type NumberAggregations = {
83
68
  sum: number;
84
69
  average: number;
85
70
  median: number;
@@ -94,28 +79,57 @@ export type NumberColumnType = ColumnType<number | undefined, number | undefined
94
79
  percentEmpty: number;
95
80
  percentFilled: number;
96
81
  percentUnique: number;
97
- }>;
98
- export type CheckboxColumnType = ColumnType<boolean | undefined, boolean | undefined, boolean | undefined, 'checkbox', {
82
+ };
83
+ type CheckboxFilters = {
99
84
  '=': number;
100
- }>;
85
+ };
86
+ /**
87
+ *
88
+ * Column types
89
+ *
90
+ */
91
+ export type ColumnType<S, U, I, R extends boolean, F extends {
92
+ [key: string]: any;
93
+ } = object, A extends {
94
+ [key: string]: any;
95
+ } = object> = {
96
+ raw: S;
97
+ insert: I;
98
+ update: U;
99
+ filters: F;
100
+ aggregations: A;
101
+ isRequired: R;
102
+ };
103
+ export type DateColumnType<R extends boolean> = ColumnType<string, string, string, R, DateFilters, DateAggregations>;
104
+ export type TextColumnType<R extends boolean> = ColumnType<string, string, string, R, TextFilters>;
105
+ export type LinkColumnType<T extends string, R extends boolean> = ColumnType<object, number | number[] | {
106
+ newIds: number[];
107
+ deletedIds: number[];
108
+ }, number | number[], R, LinkFilters, LinkAggregations> & {
109
+ linkedTo: T;
110
+ };
111
+ export type NumberColumnType<R extends boolean> = ColumnType<number, number, number, R, NumberFilters, NumberAggregations>;
112
+ export type CheckboxColumnType<R extends boolean> = ColumnType<boolean, boolean, boolean, R, CheckboxFilters>;
113
+ export type AutoGeneratedNumberColumnType = ColumnType<number, never, never, false, NumberFilters, NumberAggregations>;
114
+ export type AutoGeneratedDateColumnType = ColumnType<string, never, never, false, DateFilters, DateAggregations>;
101
115
  export type SelectTable = {
102
- id: NumberColumnType;
103
- name: TextColumnType;
104
- color: TextColumnType;
116
+ id: AutoGeneratedNumberColumnType;
117
+ name: TextColumnType<true>;
118
+ color: TextColumnType<true>;
105
119
  };
106
120
  export type AttachmentTable = {
107
- id: NumberColumnType;
108
- name: TextColumnType;
109
- metadata: TextColumnType;
110
- size: NumberColumnType;
111
- fileType: TextColumnType;
112
- url: TextColumnType;
121
+ id: AutoGeneratedNumberColumnType;
122
+ name: TextColumnType<true>;
123
+ metadata: TextColumnType<true>;
124
+ size: NumberColumnType<true>;
125
+ fileType: TextColumnType<true>;
126
+ url: TextColumnType<true>;
113
127
  };
114
128
  export type CollaboratorsTable = {
115
- id: NumberColumnType;
116
- name: TextColumnType;
117
- emailAddress: TextColumnType;
118
- avatar: TextColumnType;
129
+ id: AutoGeneratedNumberColumnType;
130
+ name: TextColumnType<true>;
131
+ emailAddress: TextColumnType<true>;
132
+ avatar: TextColumnType<true>;
119
133
  };
120
134
  export interface TaylorDatabase {
121
135
  /**
@@ -127,13 +141,5 @@ export interface TaylorDatabase {
127
141
  selectTable: SelectTable;
128
142
  attachmentTable: AttachmentTable;
129
143
  collaboratorsTable: CollaboratorsTable;
130
- customers: CustomersTable;
131
- }
132
- interface CustomersTable {
133
- id: NumberColumnType;
134
- createdAt: DateColumnType;
135
- updatedAt: DateColumnType;
136
- firstName: TextColumnType;
137
- lastName: TextColumnType;
138
144
  }
139
145
  export {};
@@ -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<{