@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.
Files changed (76) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +42 -0
  3. package/dist/cjs/__tests__/query-builder.spec.js +126 -23
  4. package/dist/cjs/__tests__/query-builder.spec.js.map +1 -1
  5. package/dist/cjs/aggregation-query-builder.d.ts +92 -0
  6. package/dist/cjs/aggregation-query-builder.js +92 -0
  7. package/dist/cjs/aggregation-query-builder.js.map +1 -1
  8. package/dist/cjs/batch-query-builder.d.ts +36 -0
  9. package/dist/cjs/batch-query-builder.js +36 -0
  10. package/dist/cjs/batch-query-builder.js.map +1 -1
  11. package/dist/cjs/delete-query-builder.d.ts +17 -0
  12. package/dist/cjs/delete-query-builder.js +17 -0
  13. package/dist/cjs/delete-query-builder.js.map +1 -1
  14. package/dist/cjs/executor.d.ts +4 -1
  15. package/dist/cjs/executor.js +20 -35
  16. package/dist/cjs/executor.js.map +1 -1
  17. package/dist/cjs/insert-query-builder.d.ts +68 -0
  18. package/dist/cjs/insert-query-builder.js +71 -0
  19. package/dist/cjs/insert-query-builder.js.map +1 -1
  20. package/dist/cjs/query-builder.d.ts +224 -5
  21. package/dist/cjs/query-builder.js +219 -5
  22. package/dist/cjs/query-builder.js.map +1 -1
  23. package/dist/cjs/selection-builder.d.ts +11 -0
  24. package/dist/cjs/selection-builder.js +11 -0
  25. package/dist/cjs/selection-builder.js.map +1 -1
  26. package/dist/cjs/{subscription-manager.d.ts → socket-connection.d.ts} +5 -4
  27. package/dist/cjs/{subscription-manager.js → socket-connection.js} +55 -9
  28. package/dist/cjs/socket-connection.js.map +1 -0
  29. package/dist/cjs/update-query-builder.d.ts +32 -0
  30. package/dist/cjs/update-query-builder.js +32 -0
  31. package/dist/cjs/update-query-builder.js.map +1 -1
  32. package/dist/cjs/where-query-builder.d.ts +59 -0
  33. package/dist/cjs/where-query-builder.js +6 -0
  34. package/dist/cjs/where-query-builder.js.map +1 -1
  35. package/dist/cjs/with-resolver.d.ts +5 -0
  36. package/dist/cjs/with-resolver.js +17 -0
  37. package/dist/cjs/with-resolver.js.map +1 -0
  38. package/dist/esm/__tests__/query-builder.spec.js +126 -23
  39. package/dist/esm/__tests__/query-builder.spec.js.map +1 -1
  40. package/dist/esm/aggregation-query-builder.d.ts +92 -0
  41. package/dist/esm/aggregation-query-builder.js +92 -0
  42. package/dist/esm/aggregation-query-builder.js.map +1 -1
  43. package/dist/esm/batch-query-builder.d.ts +36 -0
  44. package/dist/esm/batch-query-builder.js +36 -0
  45. package/dist/esm/batch-query-builder.js.map +1 -1
  46. package/dist/esm/delete-query-builder.d.ts +17 -0
  47. package/dist/esm/delete-query-builder.js +17 -0
  48. package/dist/esm/delete-query-builder.js.map +1 -1
  49. package/dist/esm/executor.d.ts +4 -1
  50. package/dist/esm/executor.js +20 -35
  51. package/dist/esm/executor.js.map +1 -1
  52. package/dist/esm/insert-query-builder.d.ts +68 -0
  53. package/dist/esm/insert-query-builder.js +71 -0
  54. package/dist/esm/insert-query-builder.js.map +1 -1
  55. package/dist/esm/query-builder.d.ts +224 -5
  56. package/dist/esm/query-builder.js +217 -4
  57. package/dist/esm/query-builder.js.map +1 -1
  58. package/dist/esm/selection-builder.d.ts +11 -0
  59. package/dist/esm/selection-builder.js +11 -0
  60. package/dist/esm/selection-builder.js.map +1 -1
  61. package/dist/esm/{subscription-manager.d.ts → socket-connection.d.ts} +5 -4
  62. package/dist/esm/{subscription-manager.js → socket-connection.js} +53 -7
  63. package/dist/esm/socket-connection.js.map +1 -0
  64. package/dist/esm/update-query-builder.d.ts +32 -0
  65. package/dist/esm/update-query-builder.js +32 -0
  66. package/dist/esm/update-query-builder.js.map +1 -1
  67. package/dist/esm/where-query-builder.d.ts +59 -0
  68. package/dist/esm/where-query-builder.js +6 -0
  69. package/dist/esm/where-query-builder.js.map +1 -1
  70. package/dist/esm/with-resolver.d.ts +5 -0
  71. package/dist/esm/with-resolver.js +14 -0
  72. package/dist/esm/with-resolver.js.map +1 -0
  73. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  74. package/package.json +4 -2
  75. package/dist/cjs/subscription-manager.js.map +0 -1
  76. package/dist/esm/subscription-manager.js.map +0 -1
@@ -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":"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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<{
@@ -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"}
@@ -2,9 +2,26 @@ import type { DeleteNode } from './@types/delete.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 deleting records from the database.
7
+ * @template DB - The database type.
8
+ * @template TableName - The name of the table to delete from.
9
+ */
5
10
  export declare class DeleteQueryBuilder<DB extends AnyDB, TableName extends keyof DB> extends FilterableQueryBuilder<DB, TableName> {
6
11
  #private;
7
12
  constructor(node: DeleteNode, executor: Executor);
13
+ /**
14
+ * Executes the delete query.
15
+ * @returns A promise that resolves with the number of affected records.
16
+ *
17
+ * @example
18
+ * ```typescript
19
+ * const { affectedRecords } = await qb
20
+ * .deleteFrom('users')
21
+ * .where('id', '=', 1)
22
+ * .execute();
23
+ * ```
24
+ */
8
25
  execute(): Promise<{
9
26
  affectedRecords: number;
10
27
  }>;
@@ -1,10 +1,27 @@
1
1
  import { FilterableQueryBuilder } from './where-query-builder.js';
2
+ /**
3
+ * A query builder for deleting records from the database.
4
+ * @template DB - The database type.
5
+ * @template TableName - The name of the table to delete from.
6
+ */
2
7
  export class DeleteQueryBuilder extends FilterableQueryBuilder {
3
8
  #node;
4
9
  constructor(node, executor) {
5
10
  super(node, executor);
6
11
  this.#node = node;
7
12
  }
13
+ /**
14
+ * Executes the delete query.
15
+ * @returns A promise that resolves with the number of affected records.
16
+ *
17
+ * @example
18
+ * ```typescript
19
+ * const { affectedRecords } = await qb
20
+ * .deleteFrom('users')
21
+ * .where('id', '=', 1)
22
+ * .execute();
23
+ * ```
24
+ */
8
25
  async execute() {
9
26
  const response = await this._executor.execute(this);
10
27
  return response[0];
@@ -1 +1 @@
1
- {"version":3,"file":"delete-query-builder.js","sourceRoot":"","sources":["../../src/delete-query-builder.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAElE,MAAM,OAAO,kBAGX,SAAQ,sBAAqC;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,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,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":"delete-query-builder.js","sourceRoot":"","sources":["../../src/delete-query-builder.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAElE;;;;GAIG;AACH,MAAM,OAAO,kBAGX,SAAQ,sBAAqC;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;;;;;;;;;;;OAWG;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,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,4 +1,5 @@
1
1
  import { AnySubscribableQueryBuilder } from './batch-query-builder.js';
2
+ import { SocketConnection } from './socket-connection.js';
2
3
  interface Compilable {
3
4
  compile(): {
4
5
  query: string;
@@ -7,7 +8,9 @@ interface Compilable {
7
8
  }
8
9
  export declare class Executor {
9
10
  #private;
10
- constructor(baseUrl: string, apiKey: string);
11
+ constructor(baseUrl: string, apiKey: string, transactionId?: string, socketConnection?: SocketConnection);
12
+ get isInTransaction(): boolean;
13
+ withTransactionId(transactionId: string): Executor;
11
14
  execute<T>(builder: Compilable): Promise<T>;
12
15
  rawRequest<T>(query: string, variables: Record<string, any>, headers?: Record<string, string>): Promise<T>;
13
16
  subscribe<TResult>(builders: AnySubscribableQueryBuilder[], callback: (result: TResult) => void): Promise<{
@@ -1,4 +1,4 @@
1
- import { SubscriptionManager } from './subscription-manager.js';
1
+ import { SocketConnection } from './socket-connection.js';
2
2
  const generateUUID = () => {
3
3
  if (globalThis.crypto && globalThis.crypto.randomUUID) {
4
4
  return globalThis.crypto.randomUUID();
@@ -13,51 +13,36 @@ const generateUUID = () => {
13
13
  export class Executor {
14
14
  #baseUrl;
15
15
  #apiKey;
16
- #subscriptionManager;
17
- constructor(baseUrl, apiKey) {
16
+ #socketConnection;
17
+ #transactionId;
18
+ constructor(baseUrl, apiKey, transactionId, socketConnection) {
18
19
  this.#baseUrl = baseUrl;
19
20
  this.#apiKey = apiKey;
20
- this.#subscriptionManager = new SubscriptionManager(this, {
21
- baseUrl,
22
- apiKey,
23
- clientId: generateUUID(),
24
- });
21
+ this.#transactionId = transactionId;
22
+ this.#socketConnection =
23
+ socketConnection ??
24
+ new SocketConnection({
25
+ baseUrl,
26
+ apiKey,
27
+ clientId: generateUUID(),
28
+ });
29
+ }
30
+ get isInTransaction() {
31
+ return !!this.#transactionId;
32
+ }
33
+ withTransactionId(transactionId) {
34
+ return new Executor(this.#baseUrl, this.#apiKey, transactionId, this.#socketConnection);
25
35
  }
26
36
  async execute(builder) {
27
37
  const { query, variables } = builder.compile();
28
38
  return this.rawRequest(query, variables);
29
39
  }
30
40
  async rawRequest(query, variables, headers) {
31
- const response = await fetch(this.#baseUrl, {
32
- method: 'POST',
33
- headers: {
34
- 'Content-Type': 'application/json',
35
- Authorization: `Bearer ${this.#apiKey}`,
36
- schema: 'readable',
37
- ...(headers ? { ...headers } : {}),
38
- },
39
- body: JSON.stringify({ query, variables }),
40
- });
41
- if (!response.ok) {
42
- const errorText = await response.text();
43
- throw new Error(`Request failed with status ${response.status}: ${errorText}`);
44
- }
45
- const jsonResponse = await response.json();
46
- if (jsonResponse.errors) {
47
- throw new Error(`GraphQL errors: ${jsonResponse.errors.map(error => error.message).join('\n')}`);
48
- }
49
- if (jsonResponse.data) {
50
- const [firstKey] = Object.keys(jsonResponse.data);
51
- if (Array.isArray(jsonResponse.data[firstKey])) {
52
- return jsonResponse.data[firstKey];
53
- }
54
- return jsonResponse.data;
55
- }
56
- throw new Error('Unexpected response format');
41
+ return this.#socketConnection.rawRequest(query, variables, headers, this.#transactionId);
57
42
  }
58
43
  subscribe(builders, callback) {
59
44
  const metadatas = builders.map(b => b._prepareMetadata());
60
- return this.#subscriptionManager.subscribe(metadatas, callback);
45
+ return this.#socketConnection.subscribe(metadatas, callback);
61
46
  }
62
47
  }
63
48
  //# sourceMappingURL=executor.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"executor.js","sourceRoot":"","sources":["../../src/executor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAMhE,MAAM,YAAY,GAAG,GAAG,EAAE;IACxB,IAAI,UAAU,CAAC,MAAM,IAAI,UAAU,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;QACtD,OAAO,UAAU,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;IACxC,CAAC;IACD,+DAA+D;IAC/D,OAAO,sCAAsC,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE;QACjE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;QACnC,MAAM,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC;QAC1C,OAAO,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACxB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,OAAO,QAAQ;IACnB,QAAQ,CAAS;IACjB,OAAO,CAAS;IAChB,oBAAoB,CAAsB;IAE1C,YAAY,OAAe,EAAE,MAAc;QACzC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QACtB,IAAI,CAAC,oBAAoB,GAAG,IAAI,mBAAmB,CAAC,IAAI,EAAE;YACxD,OAAO;YACP,MAAM;YACN,QAAQ,EAAE,YAAY,EAAE;SACzB,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,OAAO,CAAI,OAAmB;QAClC,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;QAC/C,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,UAAU,CACd,KAAa,EACb,SAA8B,EAC9B,OAAgC;QAEhC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC1C,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,UAAU,IAAI,CAAC,OAAO,EAAE;gBACvC,MAAM,EAAE,UAAU;gBAClB,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;aACnC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;SAC3C,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACxC,MAAM,IAAI,KAAK,CACb,8BAA8B,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAC9D,CAAC;QACJ,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QAE3C,IAAI,YAAY,CAAC,MAAM,EAAE,CAAC;YACxB,MAAM,IAAI,KAAK,CACb,mBAAmB,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAChF,CAAC;QACJ,CAAC;QAED,IAAI,YAAY,CAAC,IAAI,EAAE,CAAC;YACtB,MAAM,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YAClD,IAAI,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC;gBAC/C,OAAO,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAM,CAAC;YAC1C,CAAC;YACD,OAAO,YAAY,CAAC,IAAI,CAAC;QAC3B,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;IAChD,CAAC;IAED,SAAS,CACP,QAAuC,EACvC,QAAmC;QAEnC,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAE,CAAS,CAAC,gBAAgB,EAAE,CAAC,CAAC;QACnE,OAAO,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;IAClE,CAAC;CACF"}
1
+ {"version":3,"file":"executor.js","sourceRoot":"","sources":["../../src/executor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAM1D,MAAM,YAAY,GAAG,GAAG,EAAE;IACxB,IAAI,UAAU,CAAC,MAAM,IAAI,UAAU,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;QACtD,OAAO,UAAU,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;IACxC,CAAC;IACD,+DAA+D;IAC/D,OAAO,sCAAsC,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE;QACjE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;QACnC,MAAM,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC;QAC1C,OAAO,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACxB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,OAAO,QAAQ;IACnB,QAAQ,CAAS;IACjB,OAAO,CAAS;IAChB,iBAAiB,CAAmB;IACpC,cAAc,CAAU;IAExB,YACE,OAAe,EACf,MAAc,EACd,aAAsB,EACtB,gBAAmC;QAEnC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QACtB,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;QACpC,IAAI,CAAC,iBAAiB;YACpB,gBAAgB;gBAChB,IAAI,gBAAgB,CAAC;oBACnB,OAAO;oBACP,MAAM;oBACN,QAAQ,EAAE,YAAY,EAAE;iBACzB,CAAC,CAAC;IACP,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAED,iBAAiB,CAAC,aAAqB;QACrC,OAAO,IAAI,QAAQ,CACjB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,OAAO,EACZ,aAAa,EACb,IAAI,CAAC,iBAAiB,CACvB,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,OAAO,CAAI,OAAmB;QAClC,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;QAC/C,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,UAAU,CACd,KAAa,EACb,SAA8B,EAC9B,OAAgC;QAEhC,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,CACtC,KAAK,EACL,SAAS,EACT,OAAO,EACP,IAAI,CAAC,cAAc,CACpB,CAAC;IACJ,CAAC;IAED,SAAS,CACP,QAAuC,EACvC,QAAmC;QAEnC,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAE,CAAS,CAAC,gBAAgB,EAAE,CAAC,CAAC;QACnE,OAAO,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;IAC/D,CAAC;CACF"}
@@ -3,14 +3,82 @@ import type { AnyDB } from './@types/internal-types.js';
3
3
  import { NonLinkColumnNames } from './@types/query-builder.js';
4
4
  import { ResolveSelection } from './@types/type-helpers.js';
5
5
  import { Executor } from './executor.js';
6
+ /**
7
+ * A query builder for creating new records in the database.
8
+ * @template DB - The database type.
9
+ * @template TableName - The name of the table to insert into.
10
+ * @template Selection - The type of the selected fields.
11
+ */
6
12
  export declare class InsertQueryBuilder<DB extends AnyDB, TableName extends keyof DB, Selection = {
7
13
  id: number;
8
14
  }> {
9
15
  #private;
10
16
  constructor(node: InsertNode, executor: Executor);
17
+ /**
18
+ * The values to insert into the table.
19
+ * @param values - An object or array of objects representing the records to create.
20
+ * @returns The `InsertQueryBuilder` instance for chaining.
21
+ *
22
+ * @example Single Record Insertion
23
+ * ```typescript
24
+ * const newUser = await qb
25
+ * .insertInto('users')
26
+ * .values({ name: 'John Doe', email: 'john.doe@example.com' })
27
+ * .executeTakeFirst();
28
+ * ```
29
+ *
30
+ * @example Multiple Record Insertion
31
+ * ```typescript
32
+ * const newUsers = await qb
33
+ * .insertInto('users')
34
+ * .values([{ name: 'John Doe' }, { name: 'Jane Doe' }])
35
+ * .execute();
36
+ * ```
37
+ */
11
38
  values(values: Insertable<DB[TableName]> | Insertable<DB[TableName]>[]): InsertQueryBuilder<DB, TableName, Selection>;
39
+ /**
40
+ * The fields to return after the insert operation.
41
+ * @param fields - An array of field names to return.
42
+ * @returns The `InsertQueryBuilder` instance for chaining.
43
+ *
44
+ * @example
45
+ * ```typescript
46
+ * const newUser = await qb
47
+ * .insertInto('users')
48
+ * .values({ name: 'John Doe' })
49
+ * .returning(['id', 'name'])
50
+ * .executeTakeFirst();
51
+ * ```
52
+ */
12
53
  returning<const TFields extends readonly NonLinkColumnNames<DB[TableName]>[]>(fields: TFields): InsertQueryBuilder<DB, TableName, ResolveSelection<DB, TableName, TFields, object>>;
54
+ /**
55
+ * Executes the insert query.
56
+ * @returns A promise that resolves with an array of the selected fields from the inserted records.
57
+ *
58
+ * @example
59
+ * ```typescript
60
+ * const newUsers = await qb
61
+ * .insertInto('users')
62
+ * .values([{ name: 'John Doe' }, { name: 'Jane Doe' }])
63
+ * .returning(['id', 'name'])
64
+ * .execute();
65
+ * ```
66
+ */
13
67
  execute(): Promise<Selection[]>;
68
+ /**
69
+ * Executes the insert query and returns the first result.
70
+ * @returns A promise that resolves with the first inserted record, or `null` if no records were inserted.
71
+ *
72
+ * @example
73
+ * ```typescript
74
+ * const newUser = await qb
75
+ * .insertInto('users')
76
+ * .values({ name: 'John Doe' })
77
+ * .returning(['id', 'name'])
78
+ * .executeTakeFirst();
79
+ * ```
80
+ */
81
+ executeTakeFirst(): Promise<Selection | null>;
14
82
  compile(): {
15
83
  query: string;
16
84
  variables: Record<string, any>;