@neogroup/neorm 0.0.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 (161) hide show
  1. package/README.md +1019 -0
  2. package/dist/connection.d.ts +10 -0
  3. package/dist/connection.js +3 -0
  4. package/dist/connection.js.map +1 -0
  5. package/dist/data-connection.d.ts +24 -0
  6. package/dist/data-connection.js +99 -0
  7. package/dist/data-connection.js.map +1 -0
  8. package/dist/data-set.d.ts +3 -0
  9. package/dist/data-set.js +3 -0
  10. package/dist/data-set.js.map +1 -0
  11. package/dist/data-source.d.ts +23 -0
  12. package/dist/data-source.js +56 -0
  13. package/dist/data-source.js.map +1 -0
  14. package/dist/data-table.d.ts +19 -0
  15. package/dist/data-table.js +75 -0
  16. package/dist/data-table.js.map +1 -0
  17. package/dist/db.d.ts +57 -0
  18. package/dist/db.js +213 -0
  19. package/dist/db.js.map +1 -0
  20. package/dist/entities/decorators.d.ts +50 -0
  21. package/dist/entities/decorators.js +305 -0
  22. package/dist/entities/decorators.js.map +1 -0
  23. package/dist/entities/entity-query.d.ts +60 -0
  24. package/dist/entities/entity-query.js +305 -0
  25. package/dist/entities/entity-query.js.map +1 -0
  26. package/dist/entities/entity.d.ts +1 -0
  27. package/dist/entities/entity.js +3 -0
  28. package/dist/entities/entity.js.map +1 -0
  29. package/dist/entities/index.d.ts +4 -0
  30. package/dist/entities/index.js +20 -0
  31. package/dist/entities/index.js.map +1 -0
  32. package/dist/entities/relationship.d.ts +15 -0
  33. package/dist/entities/relationship.js +24 -0
  34. package/dist/entities/relationship.js.map +1 -0
  35. package/dist/index.d.ts +10 -0
  36. package/dist/index.js +32 -0
  37. package/dist/index.js.map +1 -0
  38. package/dist/query/builders/default-query-builder.d.ts +87 -0
  39. package/dist/query/builders/default-query-builder.js +524 -0
  40. package/dist/query/builders/default-query-builder.js.map +1 -0
  41. package/dist/query/builders/index.d.ts +2 -0
  42. package/dist/query/builders/index.js +19 -0
  43. package/dist/query/builders/index.js.map +1 -0
  44. package/dist/query/builders/query-builder.d.ts +5 -0
  45. package/dist/query/builders/query-builder.js +7 -0
  46. package/dist/query/builders/query-builder.js.map +1 -0
  47. package/dist/query/conditions.d.ts +60 -0
  48. package/dist/query/conditions.js +142 -0
  49. package/dist/query/conditions.js.map +1 -0
  50. package/dist/query/delete-query.d.ts +8 -0
  51. package/dist/query/delete-query.js +17 -0
  52. package/dist/query/delete-query.js.map +1 -0
  53. package/dist/query/features/has-alias.d.ts +6 -0
  54. package/dist/query/features/has-alias.js +17 -0
  55. package/dist/query/features/has-alias.js.map +1 -0
  56. package/dist/query/features/has-distinct.d.ts +6 -0
  57. package/dist/query/features/has-distinct.js +20 -0
  58. package/dist/query/features/has-distinct.js.map +1 -0
  59. package/dist/query/features/has-field-values.d.ts +9 -0
  60. package/dist/query/features/has-field-values.js +27 -0
  61. package/dist/query/features/has-field-values.js.map +1 -0
  62. package/dist/query/features/has-group-by-fields.d.ts +7 -0
  63. package/dist/query/features/has-group-by-fields.js +21 -0
  64. package/dist/query/features/has-group-by-fields.js.map +1 -0
  65. package/dist/query/features/has-having-conditions.d.ts +13 -0
  66. package/dist/query/features/has-having-conditions.js +28 -0
  67. package/dist/query/features/has-having-conditions.js.map +1 -0
  68. package/dist/query/features/has-joins.d.ts +41 -0
  69. package/dist/query/features/has-joins.js +67 -0
  70. package/dist/query/features/has-joins.js.map +1 -0
  71. package/dist/query/features/has-limit.d.ts +6 -0
  72. package/dist/query/features/has-limit.js +20 -0
  73. package/dist/query/features/has-limit.js.map +1 -0
  74. package/dist/query/features/has-offset.d.ts +6 -0
  75. package/dist/query/features/has-offset.js +20 -0
  76. package/dist/query/features/has-offset.js.map +1 -0
  77. package/dist/query/features/has-order-by-fields.d.ts +15 -0
  78. package/dist/query/features/has-order-by-fields.js +38 -0
  79. package/dist/query/features/has-order-by-fields.js.map +1 -0
  80. package/dist/query/features/has-select-fields.d.ts +11 -0
  81. package/dist/query/features/has-select-fields.js +21 -0
  82. package/dist/query/features/has-select-fields.js.map +1 -0
  83. package/dist/query/features/has-table.d.ts +7 -0
  84. package/dist/query/features/has-table.js +20 -0
  85. package/dist/query/features/has-table.js.map +1 -0
  86. package/dist/query/features/has-unions.d.ts +13 -0
  87. package/dist/query/features/has-unions.js +21 -0
  88. package/dist/query/features/has-unions.js.map +1 -0
  89. package/dist/query/features/has-when.d.ts +3 -0
  90. package/dist/query/features/has-when.js +13 -0
  91. package/dist/query/features/has-when.js.map +1 -0
  92. package/dist/query/features/has-where-conditions.d.ts +35 -0
  93. package/dist/query/features/has-where-conditions.js +92 -0
  94. package/dist/query/features/has-where-conditions.js.map +1 -0
  95. package/dist/query/features/index.d.ts +14 -0
  96. package/dist/query/features/index.js +31 -0
  97. package/dist/query/features/index.js.map +1 -0
  98. package/dist/query/fields.d.ts +12 -0
  99. package/dist/query/fields.js +18 -0
  100. package/dist/query/fields.js.map +1 -0
  101. package/dist/query/index.d.ts +11 -0
  102. package/dist/query/index.js +28 -0
  103. package/dist/query/index.js.map +1 -0
  104. package/dist/query/insert-query.d.ts +8 -0
  105. package/dist/query/insert-query.js +17 -0
  106. package/dist/query/insert-query.js.map +1 -0
  107. package/dist/query/query.d.ts +2 -0
  108. package/dist/query/query.js +7 -0
  109. package/dist/query/query.js.map +1 -0
  110. package/dist/query/select-query.d.ts +9 -0
  111. package/dist/query/select-query.js +33 -0
  112. package/dist/query/select-query.js.map +1 -0
  113. package/dist/query/statement.d.ts +4 -0
  114. package/dist/query/statement.js +3 -0
  115. package/dist/query/statement.js.map +1 -0
  116. package/dist/query/table.d.ts +6 -0
  117. package/dist/query/table.js +3 -0
  118. package/dist/query/table.js.map +1 -0
  119. package/dist/query/update-query.d.ts +8 -0
  120. package/dist/query/update-query.js +17 -0
  121. package/dist/query/update-query.js.map +1 -0
  122. package/dist/sources/mysql/index.d.ts +3 -0
  123. package/dist/sources/mysql/index.js +20 -0
  124. package/dist/sources/mysql/index.js.map +1 -0
  125. package/dist/sources/mysql/mysql-connection.d.ts +14 -0
  126. package/dist/sources/mysql/mysql-connection.js +36 -0
  127. package/dist/sources/mysql/mysql-connection.js.map +1 -0
  128. package/dist/sources/mysql/mysql-data-source.d.ts +24 -0
  129. package/dist/sources/mysql/mysql-data-source.js +72 -0
  130. package/dist/sources/mysql/mysql-data-source.js.map +1 -0
  131. package/dist/sources/mysql/mysql-query-builder.d.ts +8 -0
  132. package/dist/sources/mysql/mysql-query-builder.js +28 -0
  133. package/dist/sources/mysql/mysql-query-builder.js.map +1 -0
  134. package/dist/sources/postgres/index.d.ts +2 -0
  135. package/dist/sources/postgres/index.js +19 -0
  136. package/dist/sources/postgres/index.js.map +1 -0
  137. package/dist/sources/postgres/postgres-connection.d.ts +13 -0
  138. package/dist/sources/postgres/postgres-connection.js +40 -0
  139. package/dist/sources/postgres/postgres-connection.js.map +1 -0
  140. package/dist/sources/postgres/postgres-data-source.d.ts +24 -0
  141. package/dist/sources/postgres/postgres-data-source.js +73 -0
  142. package/dist/sources/postgres/postgres-data-source.js.map +1 -0
  143. package/dist/sources/postgres/postgres-query-builder.d.ts +5 -0
  144. package/dist/sources/postgres/postgres-query-builder.js +13 -0
  145. package/dist/sources/postgres/postgres-query-builder.js.map +1 -0
  146. package/dist/sources/sqlite/index.d.ts +3 -0
  147. package/dist/sources/sqlite/index.js +20 -0
  148. package/dist/sources/sqlite/index.js.map +1 -0
  149. package/dist/sources/sqlite/sqlite-connection.d.ts +14 -0
  150. package/dist/sources/sqlite/sqlite-connection.js +37 -0
  151. package/dist/sources/sqlite/sqlite-connection.js.map +1 -0
  152. package/dist/sources/sqlite/sqlite-data-source.d.ts +11 -0
  153. package/dist/sources/sqlite/sqlite-data-source.js +34 -0
  154. package/dist/sources/sqlite/sqlite-data-source.js.map +1 -0
  155. package/dist/sources/sqlite/sqlite-query-builder.d.ts +6 -0
  156. package/dist/sources/sqlite/sqlite-query-builder.js +23 -0
  157. package/dist/sources/sqlite/sqlite-query-builder.js.map +1 -0
  158. package/dist/utilities.d.ts +2 -0
  159. package/dist/utilities.js +17 -0
  160. package/dist/utilities.js.map +1 -0
  161. package/package.json +56 -0
@@ -0,0 +1,524 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DefaultQueryBuilder = void 0;
4
+ const conditions_1 = require("../conditions");
5
+ const delete_query_1 = require("../delete-query");
6
+ const features_1 = require("../features");
7
+ const insert_query_1 = require("../insert-query");
8
+ const select_query_1 = require("../select-query");
9
+ const update_query_1 = require("../update-query");
10
+ const query_builder_1 = require("./query-builder");
11
+ class DefaultQueryBuilder extends query_builder_1.QueryBuilder {
12
+ buildQuery(query) {
13
+ const statement = { sql: '', bindings: [] };
14
+ if (query instanceof select_query_1.SelectQuery) {
15
+ this.buildSelectQuery(query, statement);
16
+ }
17
+ else if (query instanceof insert_query_1.InsertQuery) {
18
+ this.buildInsertQuery(query, statement);
19
+ }
20
+ else if (query instanceof update_query_1.UpdateQuery) {
21
+ this.buildUpdateQuery(query, statement);
22
+ }
23
+ else if (query instanceof delete_query_1.DeleteQuery) {
24
+ this.buildDeleteQuery(query, statement);
25
+ }
26
+ return statement;
27
+ }
28
+ buildSelectQuery(query, statement) {
29
+ statement.sql += DefaultQueryBuilder.SELECT;
30
+ if (query.isDistinct()) {
31
+ statement.sql += DefaultQueryBuilder.SPACE;
32
+ statement.sql += DefaultQueryBuilder.DISTINCT;
33
+ }
34
+ statement.sql += DefaultQueryBuilder.SPACE;
35
+ const selectFields = query.getSelectFields();
36
+ if (selectFields && selectFields.length > 0) {
37
+ let isFirst = true;
38
+ for (const field of selectFields) {
39
+ if (!isFirst) {
40
+ statement.sql += DefaultQueryBuilder.COMMA;
41
+ statement.sql += DefaultQueryBuilder.SPACE;
42
+ }
43
+ this.buildSelectField(field, statement);
44
+ isFirst = false;
45
+ }
46
+ }
47
+ else {
48
+ statement.sql += DefaultQueryBuilder.ALL;
49
+ }
50
+ statement.sql += DefaultQueryBuilder.SPACE;
51
+ statement.sql += DefaultQueryBuilder.FROM;
52
+ statement.sql += DefaultQueryBuilder.SPACE;
53
+ this.buildTable(query.getTable(), statement);
54
+ const tableAlias = query.getAlias();
55
+ if (tableAlias != null) {
56
+ statement.sql += DefaultQueryBuilder.SPACE;
57
+ statement.sql += DefaultQueryBuilder.AS;
58
+ statement.sql += DefaultQueryBuilder.SPACE;
59
+ statement.sql += tableAlias;
60
+ }
61
+ const joins = query.getJoins();
62
+ if (joins != null && joins.length > 0) {
63
+ for (const join of joins) {
64
+ statement.sql += DefaultQueryBuilder.SPACE;
65
+ this.buildJoin(join, statement);
66
+ }
67
+ }
68
+ const whereConditions = query.getWhereConditions();
69
+ if (whereConditions && whereConditions.getConditions().length > 0) {
70
+ statement.sql += DefaultQueryBuilder.SPACE;
71
+ statement.sql += DefaultQueryBuilder.WHERE;
72
+ statement.sql += DefaultQueryBuilder.SPACE;
73
+ this.buildConditionGroup(whereConditions, statement);
74
+ }
75
+ const groupByFields = query.getGroupByFields();
76
+ if (groupByFields && groupByFields.length > 0) {
77
+ statement.sql += DefaultQueryBuilder.SPACE;
78
+ statement.sql += DefaultQueryBuilder.GROUP;
79
+ statement.sql += DefaultQueryBuilder.SPACE;
80
+ statement.sql += DefaultQueryBuilder.BY;
81
+ statement.sql += DefaultQueryBuilder.SPACE;
82
+ let isFirst = true;
83
+ for (const field of groupByFields) {
84
+ if (!isFirst) {
85
+ statement.sql += DefaultQueryBuilder.COMMA;
86
+ statement.sql += DefaultQueryBuilder.SPACE;
87
+ }
88
+ this.buildField(field, statement);
89
+ isFirst = false;
90
+ }
91
+ }
92
+ const havingConditions = query.getHavingConditions();
93
+ if (havingConditions && havingConditions.getConditions().length > 0) {
94
+ statement.sql += DefaultQueryBuilder.SPACE;
95
+ statement.sql += DefaultQueryBuilder.HAVING;
96
+ statement.sql += DefaultQueryBuilder.SPACE;
97
+ this.buildConditionGroup(havingConditions, statement);
98
+ }
99
+ const orderByFields = query.getOrderByFields();
100
+ if (orderByFields && orderByFields.length > 0) {
101
+ statement.sql += DefaultQueryBuilder.SPACE;
102
+ statement.sql += DefaultQueryBuilder.ORDER;
103
+ statement.sql += DefaultQueryBuilder.SPACE;
104
+ statement.sql += DefaultQueryBuilder.BY;
105
+ statement.sql += DefaultQueryBuilder.SPACE;
106
+ let isFirst = true;
107
+ for (const field of orderByFields) {
108
+ if (!isFirst) {
109
+ statement.sql += DefaultQueryBuilder.COMMA;
110
+ statement.sql += DefaultQueryBuilder.SPACE;
111
+ }
112
+ this.buildOrderByField(field, statement);
113
+ isFirst = false;
114
+ }
115
+ }
116
+ this.buildLimitOffset(query, statement);
117
+ for (const { query: unionQuery, all } of query.getUnions()) {
118
+ statement.sql += DefaultQueryBuilder.SPACE;
119
+ statement.sql += DefaultQueryBuilder.UNION;
120
+ if (all) {
121
+ statement.sql += DefaultQueryBuilder.SPACE;
122
+ statement.sql += 'ALL';
123
+ }
124
+ statement.sql += DefaultQueryBuilder.SPACE;
125
+ this.buildSelectQuery(unionQuery, statement);
126
+ }
127
+ }
128
+ buildLimitOffset(query, statement) {
129
+ if (query.getLimit() >= 0) {
130
+ statement.sql += DefaultQueryBuilder.SPACE;
131
+ statement.sql += DefaultQueryBuilder.LIMIT;
132
+ statement.sql += DefaultQueryBuilder.SPACE;
133
+ statement.sql += query.getLimit();
134
+ }
135
+ if (query.getOffset() >= 0) {
136
+ statement.sql += DefaultQueryBuilder.SPACE;
137
+ statement.sql += DefaultQueryBuilder.OFFSET;
138
+ statement.sql += DefaultQueryBuilder.SPACE;
139
+ statement.sql += query.getOffset();
140
+ }
141
+ }
142
+ buildInsertQuery(query, statement) {
143
+ statement.sql += DefaultQueryBuilder.INSERT;
144
+ statement.sql += DefaultQueryBuilder.SPACE;
145
+ statement.sql += DefaultQueryBuilder.INTO;
146
+ statement.sql += DefaultQueryBuilder.SPACE;
147
+ this.buildTable(query.getTable(), statement);
148
+ statement.sql += DefaultQueryBuilder.SPACE;
149
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
150
+ const fields = query.getFields();
151
+ let isFirst = true;
152
+ for (const fieldName in fields) {
153
+ if (!isFirst) {
154
+ statement.sql += DefaultQueryBuilder.COMMA;
155
+ statement.sql += DefaultQueryBuilder.SPACE;
156
+ }
157
+ statement.sql += fieldName;
158
+ isFirst = false;
159
+ }
160
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
161
+ statement.sql += DefaultQueryBuilder.SPACE;
162
+ statement.sql += DefaultQueryBuilder.VALUES;
163
+ statement.sql += DefaultQueryBuilder.SPACE;
164
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
165
+ isFirst = true;
166
+ for (const field in fields) {
167
+ const fieldValue = fields[field];
168
+ if (!isFirst) {
169
+ statement.sql += DefaultQueryBuilder.COMMA;
170
+ statement.sql += DefaultQueryBuilder.SPACE;
171
+ }
172
+ this.buildValue(fieldValue, statement);
173
+ isFirst = false;
174
+ }
175
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
176
+ }
177
+ buildUpdateQuery(query, statement) {
178
+ statement.sql += DefaultQueryBuilder.UPDATE;
179
+ statement.sql += DefaultQueryBuilder.SPACE;
180
+ this.buildTable(query.getTable(), statement);
181
+ statement.sql += DefaultQueryBuilder.SPACE;
182
+ statement.sql += DefaultQueryBuilder.SET;
183
+ statement.sql += DefaultQueryBuilder.SPACE;
184
+ const fields = query.getFields();
185
+ let isFirst = true;
186
+ for (const fieldName in fields) {
187
+ if (!isFirst) {
188
+ statement.sql += DefaultQueryBuilder.COMMA;
189
+ statement.sql += DefaultQueryBuilder.SPACE;
190
+ }
191
+ statement.sql += fieldName;
192
+ statement.sql += DefaultQueryBuilder.SPACE;
193
+ statement.sql += DefaultQueryBuilder.EQUALS;
194
+ statement.sql += DefaultQueryBuilder.SPACE;
195
+ this.buildValue(fields[fieldName], statement);
196
+ isFirst = false;
197
+ }
198
+ const whereConditions = query.getWhereConditions();
199
+ if (whereConditions && whereConditions.getConditions().length > 0) {
200
+ statement.sql += DefaultQueryBuilder.SPACE;
201
+ statement.sql += DefaultQueryBuilder.WHERE;
202
+ statement.sql += DefaultQueryBuilder.SPACE;
203
+ this.buildConditionGroup(whereConditions, statement);
204
+ }
205
+ }
206
+ buildDeleteQuery(query, statement) {
207
+ statement.sql += DefaultQueryBuilder.DELETE;
208
+ statement.sql += DefaultQueryBuilder.SPACE;
209
+ statement.sql += DefaultQueryBuilder.FROM;
210
+ statement.sql += DefaultQueryBuilder.SPACE;
211
+ this.buildTable(query.getTable(), statement);
212
+ const whereConditions = query.getWhereConditions();
213
+ if (whereConditions && whereConditions.getConditions().length > 0) {
214
+ statement.sql += DefaultQueryBuilder.SPACE;
215
+ statement.sql += DefaultQueryBuilder.WHERE;
216
+ statement.sql += DefaultQueryBuilder.SPACE;
217
+ this.buildConditionGroup(whereConditions, statement);
218
+ }
219
+ }
220
+ /**
221
+ * Outputs a plain identifier (column name). Override in engine-specific
222
+ * subclasses to add quoting (e.g. backticks for MySQL).
223
+ */
224
+ buildFieldName(name, statement) {
225
+ statement.sql += name;
226
+ }
227
+ /**
228
+ * Parses and outputs a raw string field, supporting:
229
+ * - 'field' → plain identifier
230
+ * - 'table.field' → quoted table + field (engine-aware)
231
+ * - 'FUNC(field)' → function call, field parsed recursively
232
+ * - 'FUNC(table.field)' → function call with qualified field
233
+ * - Any string with spaces is treated as a raw SQL expression and
234
+ * passed through as-is (e.g. 'COUNT(*) AS total').
235
+ */
236
+ buildRawFieldString(raw, statement) {
237
+ if (raw.includes(' ')) {
238
+ statement.sql += raw;
239
+ return;
240
+ }
241
+ const funcMatch = raw.match(/^(\w+)\((.+)\)$/);
242
+ if (funcMatch) {
243
+ statement.sql += funcMatch[1].toUpperCase();
244
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
245
+ this.buildRawFieldString(funcMatch[2].trim(), statement);
246
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
247
+ return;
248
+ }
249
+ if (raw === DefaultQueryBuilder.ALL) {
250
+ statement.sql += DefaultQueryBuilder.ALL;
251
+ return;
252
+ }
253
+ const dotIndex = raw.indexOf('.');
254
+ if (dotIndex !== -1) {
255
+ this.buildTable(raw.substring(0, dotIndex), statement);
256
+ statement.sql += DefaultQueryBuilder.POINT;
257
+ this.buildFieldName(raw.substring(dotIndex + 1), statement);
258
+ return;
259
+ }
260
+ this.buildFieldName(raw, statement);
261
+ }
262
+ buildSelectField(field, statement) {
263
+ if (typeof field === 'string' || field instanceof String) {
264
+ this.buildRawFieldString(field, statement);
265
+ }
266
+ else {
267
+ if (field.function) {
268
+ statement.sql += field.function.toUpperCase();
269
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
270
+ }
271
+ if (field.table) {
272
+ this.buildTable(field.table, statement);
273
+ statement.sql += DefaultQueryBuilder.POINT;
274
+ }
275
+ this.buildFieldName(field.name, statement);
276
+ if (field.function) {
277
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
278
+ }
279
+ if (field.alias) {
280
+ statement.sql += DefaultQueryBuilder.SPACE;
281
+ statement.sql += DefaultQueryBuilder.AS;
282
+ statement.sql += DefaultQueryBuilder.SPACE;
283
+ statement.sql += field.alias;
284
+ }
285
+ }
286
+ }
287
+ buildOrderByField(field, statement) {
288
+ if (typeof field === 'string' || field instanceof String) {
289
+ this.buildRawFieldString(field, statement);
290
+ }
291
+ else if (field instanceof Array) {
292
+ const [fieldName, direction] = field;
293
+ statement.sql += fieldName;
294
+ statement.sql += DefaultQueryBuilder.SPACE;
295
+ statement.sql += direction;
296
+ }
297
+ else {
298
+ if (field.table) {
299
+ this.buildTable(field.table, statement);
300
+ statement.sql += DefaultQueryBuilder.POINT;
301
+ }
302
+ this.buildFieldName(field.name, statement);
303
+ if (field.direction) {
304
+ statement.sql += DefaultQueryBuilder.SPACE;
305
+ statement.sql += field.direction;
306
+ }
307
+ }
308
+ }
309
+ buildField(field, statement) {
310
+ if (typeof field === 'string' || field instanceof String) {
311
+ this.buildRawFieldString(field, statement);
312
+ }
313
+ else {
314
+ if (field.table) {
315
+ this.buildTable(field.table, statement);
316
+ statement.sql += DefaultQueryBuilder.POINT;
317
+ }
318
+ this.buildFieldName(field.name, statement);
319
+ }
320
+ }
321
+ buildCondition(condition, statement) {
322
+ if (typeof condition === 'string' || condition instanceof String) {
323
+ statement.sql += condition;
324
+ }
325
+ else if (condition instanceof conditions_1.ConditionGroup) {
326
+ this.buildConditionGroup(condition, statement);
327
+ }
328
+ else if ('sql' in condition) {
329
+ const { sql, bindings } = condition;
330
+ statement.sql = sql;
331
+ statement.bindings.push(...bindings);
332
+ }
333
+ else if ('column' in condition) {
334
+ const { field, operator, column } = condition;
335
+ this.buildField(field, statement);
336
+ statement.sql += DefaultQueryBuilder.SPACE;
337
+ this.buildOperator(operator, statement);
338
+ statement.sql += DefaultQueryBuilder.SPACE;
339
+ this.buildField(column, statement);
340
+ }
341
+ else if ('field' in condition) {
342
+ const { field, operator, value } = condition;
343
+ this.buildField(field, statement);
344
+ statement.sql += DefaultQueryBuilder.SPACE;
345
+ if (value === null && (operator === '=' || operator === '!=' || operator === '<>')) {
346
+ statement.sql += DefaultQueryBuilder.IS;
347
+ statement.sql += DefaultQueryBuilder.SPACE;
348
+ if (operator !== '=') {
349
+ statement.sql += DefaultQueryBuilder.NOT;
350
+ statement.sql += DefaultQueryBuilder.SPACE;
351
+ }
352
+ statement.sql += DefaultQueryBuilder.NULL;
353
+ }
354
+ else if (operator && /^(NOT\s+)?BETWEEN$/i.test(operator) && Array.isArray(value) && value.length === 2) {
355
+ this.buildOperator(operator, statement);
356
+ statement.sql += DefaultQueryBuilder.SPACE;
357
+ this.buildSingleValue(value[0], statement);
358
+ statement.sql += DefaultQueryBuilder.SPACE;
359
+ statement.sql += DefaultQueryBuilder.AND;
360
+ statement.sql += DefaultQueryBuilder.SPACE;
361
+ this.buildSingleValue(value[1], statement);
362
+ }
363
+ else if (operator) {
364
+ this.buildOperator(operator, statement);
365
+ statement.sql += DefaultQueryBuilder.SPACE;
366
+ if (value != undefined) {
367
+ this.buildValue(value, statement);
368
+ }
369
+ }
370
+ }
371
+ }
372
+ buildConditionGroup(conditionGroup, statement) {
373
+ let isFirst = true;
374
+ for (const { connector, condition } of conditionGroup.getConditions()) {
375
+ if (!isFirst) {
376
+ statement.sql += DefaultQueryBuilder.SPACE;
377
+ statement.sql += connector == conditions_1.ConditionConnector.AND ? DefaultQueryBuilder.AND : DefaultQueryBuilder.OR;
378
+ statement.sql += DefaultQueryBuilder.SPACE;
379
+ }
380
+ if (condition instanceof conditions_1.ConditionGroup) {
381
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
382
+ this.buildConditionGroup(condition, statement);
383
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
384
+ }
385
+ else {
386
+ this.buildCondition(condition, statement);
387
+ }
388
+ isFirst = false;
389
+ }
390
+ }
391
+ buildJoin(join, statement) {
392
+ const { type, table, condition, alias } = join;
393
+ switch (type) {
394
+ case features_1.JoinType.INNER_JOIN:
395
+ statement.sql += DefaultQueryBuilder.INNER;
396
+ statement.sql += DefaultQueryBuilder.SPACE;
397
+ break;
398
+ case features_1.JoinType.OUTER_JOIN:
399
+ statement.sql += DefaultQueryBuilder.OUTER;
400
+ statement.sql += DefaultQueryBuilder.SPACE;
401
+ break;
402
+ case features_1.JoinType.LEFT_JOIN:
403
+ statement.sql += DefaultQueryBuilder.LEFT;
404
+ statement.sql += DefaultQueryBuilder.SPACE;
405
+ break;
406
+ case features_1.JoinType.RIGHT_JOIN:
407
+ statement.sql += DefaultQueryBuilder.RIGHT;
408
+ statement.sql += DefaultQueryBuilder.SPACE;
409
+ break;
410
+ case features_1.JoinType.CROSS_JOIN:
411
+ statement.sql += DefaultQueryBuilder.CROSS;
412
+ statement.sql += DefaultQueryBuilder.SPACE;
413
+ break;
414
+ }
415
+ statement.sql += DefaultQueryBuilder.JOIN;
416
+ statement.sql += DefaultQueryBuilder.SPACE;
417
+ this.buildTable(table, statement);
418
+ if (alias) {
419
+ statement.sql += DefaultQueryBuilder.SPACE;
420
+ statement.sql += DefaultQueryBuilder.AS;
421
+ statement.sql += DefaultQueryBuilder.SPACE;
422
+ statement.sql += alias;
423
+ }
424
+ statement.sql += DefaultQueryBuilder.SPACE;
425
+ statement.sql += DefaultQueryBuilder.ON;
426
+ statement.sql += DefaultQueryBuilder.SPACE;
427
+ this.buildConditionGroup(condition, statement);
428
+ }
429
+ buildTable(table, statement) {
430
+ if (typeof table === 'string' || table instanceof String) {
431
+ statement.sql += table;
432
+ }
433
+ else {
434
+ if (table.schema) {
435
+ statement.sql += table.schema;
436
+ statement.sql += DefaultQueryBuilder.POINT;
437
+ }
438
+ statement.sql += table.name;
439
+ }
440
+ }
441
+ buildValue(value, statement) {
442
+ if (value === null || value === undefined) {
443
+ this.buildSingleValue(value, statement);
444
+ }
445
+ else if (Array.isArray(value)) {
446
+ this.buildArrayValue(value, statement);
447
+ }
448
+ else if (value instanceof select_query_1.SelectQuery) {
449
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
450
+ this.buildSelectQuery(value, statement);
451
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
452
+ }
453
+ else if (typeof value === 'object') {
454
+ this.buildField(value, statement);
455
+ }
456
+ else {
457
+ this.buildSingleValue(value, statement);
458
+ }
459
+ }
460
+ buildArrayValue(value, statement) {
461
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_START;
462
+ let isFirst = true;
463
+ for (const valueItem of value) {
464
+ if (!isFirst) {
465
+ statement.sql += DefaultQueryBuilder.COMMA;
466
+ statement.sql += DefaultQueryBuilder.SPACE;
467
+ }
468
+ this.buildSingleValue(valueItem, statement);
469
+ isFirst = false;
470
+ }
471
+ statement.sql += DefaultQueryBuilder.PARENTHESIS_END;
472
+ }
473
+ buildSingleValue(value, statement) {
474
+ statement.sql += DefaultQueryBuilder.WILDCARD;
475
+ statement.bindings.push(value);
476
+ }
477
+ buildOperator(operator, statement) {
478
+ statement.sql += operator.toUpperCase();
479
+ }
480
+ }
481
+ exports.DefaultQueryBuilder = DefaultQueryBuilder;
482
+ DefaultQueryBuilder.SPACE = ' ';
483
+ DefaultQueryBuilder.COMMA = ',';
484
+ DefaultQueryBuilder.DOUBLE_QUOTES = '"';
485
+ DefaultQueryBuilder.EQUALS = '=';
486
+ DefaultQueryBuilder.PARENTHESIS_START = '(';
487
+ DefaultQueryBuilder.PARENTHESIS_END = ')';
488
+ DefaultQueryBuilder.SELECT = 'SELECT';
489
+ DefaultQueryBuilder.INSERT = 'INSERT';
490
+ DefaultQueryBuilder.UPDATE = 'UPDATE';
491
+ DefaultQueryBuilder.DELETE = 'DELETE';
492
+ DefaultQueryBuilder.INTO = 'INTO';
493
+ DefaultQueryBuilder.SET = 'SET';
494
+ DefaultQueryBuilder.VALUES = 'VALUES';
495
+ DefaultQueryBuilder.DISTINCT = 'DISTINCT';
496
+ DefaultQueryBuilder.ALL = '*';
497
+ DefaultQueryBuilder.AS = 'AS';
498
+ DefaultQueryBuilder.POINT = '.';
499
+ DefaultQueryBuilder.FROM = 'FROM';
500
+ DefaultQueryBuilder.AND = 'AND';
501
+ DefaultQueryBuilder.OR = 'OR';
502
+ DefaultQueryBuilder.NULL = 'NULL';
503
+ DefaultQueryBuilder.IS = 'IS';
504
+ DefaultQueryBuilder.NOT = 'NOT';
505
+ DefaultQueryBuilder.ON = 'ON';
506
+ DefaultQueryBuilder.WHERE = 'WHERE';
507
+ DefaultQueryBuilder.HAVING = 'HAVING';
508
+ DefaultQueryBuilder.GROUP = 'GROUP';
509
+ DefaultQueryBuilder.ORDER = 'ORDER';
510
+ DefaultQueryBuilder.BY = 'BY';
511
+ DefaultQueryBuilder.LIMIT = 'LIMIT';
512
+ DefaultQueryBuilder.OFFSET = 'OFFSET';
513
+ DefaultQueryBuilder.ASC = 'ASC';
514
+ DefaultQueryBuilder.DESC = 'DESC';
515
+ DefaultQueryBuilder.JOIN = 'JOIN';
516
+ DefaultQueryBuilder.INNER = 'INNER';
517
+ DefaultQueryBuilder.OUTER = 'OUTER';
518
+ DefaultQueryBuilder.LEFT = 'LEFT';
519
+ DefaultQueryBuilder.RIGHT = 'RIGHT';
520
+ DefaultQueryBuilder.CROSS = 'CROSS';
521
+ DefaultQueryBuilder.WILDCARD = '?';
522
+ DefaultQueryBuilder.UNION = 'UNION';
523
+ DefaultQueryBuilder.BETWEEN = 'BETWEEN';
524
+ //# sourceMappingURL=default-query-builder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"default-query-builder.js","sourceRoot":"","sources":["../../../src/query/builders/default-query-builder.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './default-query-builder';
2
+ export * from './query-builder';
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./default-query-builder"), exports);
18
+ __exportStar(require("./query-builder"), exports);
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/query/builders/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0DAAuC;AACvC,kDAA+B"}
@@ -0,0 +1,5 @@
1
+ import { Query } from '../query';
2
+ import { Statement } from '../statement';
3
+ export declare abstract class QueryBuilder {
4
+ abstract buildQuery(query: Query): Statement;
5
+ }
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.QueryBuilder = void 0;
4
+ class QueryBuilder {
5
+ }
6
+ exports.QueryBuilder = QueryBuilder;
7
+ //# sourceMappingURL=query-builder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query-builder.js","sourceRoot":"","sources":["../../../src/query/builders/query-builder.ts"],"names":[],"mappings":";;;AAGA,MAAsB,YAAY;CAEjC;AAFD,oCAEC"}
@@ -0,0 +1,60 @@
1
+ import { Field } from './fields';
2
+ export type BasicCondition = {
3
+ field: Field;
4
+ operator?: string;
5
+ value: any;
6
+ };
7
+ export type ColumnCondition = {
8
+ field: Field;
9
+ operator: string;
10
+ column: Field;
11
+ };
12
+ export type RawCondition = string | {
13
+ sql: string;
14
+ bindings: Array<any>;
15
+ };
16
+ export declare enum ConditionConnector {
17
+ AND = 0,
18
+ OR = 1
19
+ }
20
+ export type Condition = RawCondition | BasicCondition | ColumnCondition | ConditionGroup | ((group: ConditionGroup) => void);
21
+ export type ConnectedCondition = {
22
+ condition: Condition;
23
+ connector: ConditionConnector;
24
+ };
25
+ export declare class ConditionGroup {
26
+ private conditions;
27
+ setConditions(conditions: Array<ConnectedCondition>): ConditionGroup;
28
+ getConditions(): Array<{
29
+ condition: Condition;
30
+ connector: ConditionConnector;
31
+ }>;
32
+ where(callback: (group: ConditionGroup) => void): ConditionGroup;
33
+ where(condition: Condition): ConditionGroup;
34
+ where(field: Field, value: any): ConditionGroup;
35
+ where(field: Field, operator: string, value: any): ConditionGroup;
36
+ orWhere(callback: (group: ConditionGroup) => void): ConditionGroup;
37
+ orWhere(condition: Condition): ConditionGroup;
38
+ orWhere(field: Field, value: any): ConditionGroup;
39
+ orWhere(field: Field, operator: string, value: any): ConditionGroup;
40
+ whereIn(field: Field, values: Array<any>): ConditionGroup;
41
+ whereNotIn(field: Field, values: Array<any>): ConditionGroup;
42
+ whereBetween(field: Field, range: [any, any]): ConditionGroup;
43
+ whereNotBetween(field: Field, range: [any, any]): ConditionGroup;
44
+ whereNull(field: Field): ConditionGroup;
45
+ whereNotNull(field: Field): ConditionGroup;
46
+ whereLike(field: Field, pattern: string): ConditionGroup;
47
+ whereNotLike(field: Field, pattern: string): ConditionGroup;
48
+ whereColumn(field: Field, column: Field): ConditionGroup;
49
+ whereColumn(field: Field, operator: string, column: Field): ConditionGroup;
50
+ orWhereIn(field: Field, values: Array<any>): ConditionGroup;
51
+ orWhereNotIn(field: Field, values: Array<any>): ConditionGroup;
52
+ orWhereBetween(field: Field, range: [any, any]): ConditionGroup;
53
+ orWhereNotBetween(field: Field, range: [any, any]): ConditionGroup;
54
+ orWhereNull(field: Field): ConditionGroup;
55
+ orWhereNotNull(field: Field): ConditionGroup;
56
+ orWhereLike(field: Field, pattern: string): ConditionGroup;
57
+ orWhereNotLike(field: Field, pattern: string): ConditionGroup;
58
+ orWhereColumn(field: Field, column: Field): ConditionGroup;
59
+ orWhereColumn(field: Field, operator: string, column: Field): ConditionGroup;
60
+ }