@sqb/builder 4.20.7 → 4.21.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 (187) hide show
  1. package/package.json +8 -24
  2. package/{types/sql-objects → sql-objects}/join-statement.d.ts +4 -4
  3. package/{types/typeguards.d.ts → typeguards.d.ts} +4 -3
  4. package/{esm/typeguards.js → typeguards.js} +4 -4
  5. package/cjs/classes.ns.js +0 -41
  6. package/cjs/enums.js +0 -102
  7. package/cjs/extensions.js +0 -38
  8. package/cjs/helpers.js +0 -30
  9. package/cjs/index.js +0 -25
  10. package/cjs/op.initializers.js +0 -163
  11. package/cjs/package.json +0 -3
  12. package/cjs/query/delete-query.js +0 -57
  13. package/cjs/query/insert-query.js +0 -86
  14. package/cjs/query/query.js +0 -41
  15. package/cjs/query/returning-query.js +0 -46
  16. package/cjs/query/select-query.js +0 -297
  17. package/cjs/query/union-query.js +0 -32
  18. package/cjs/query/update-query.js +0 -86
  19. package/cjs/serializable.js +0 -6
  20. package/cjs/serialize-context.js +0 -203
  21. package/cjs/sql-objects/base-field.js +0 -11
  22. package/cjs/sql-objects/case-statement.js +0 -91
  23. package/cjs/sql-objects/coalesce-statement.js +0 -48
  24. package/cjs/sql-objects/count-statement.js +0 -37
  25. package/cjs/sql-objects/expression.js +0 -10
  26. package/cjs/sql-objects/field-expression.js +0 -54
  27. package/cjs/sql-objects/group-column.js +0 -36
  28. package/cjs/sql-objects/join-statement.js +0 -94
  29. package/cjs/sql-objects/lower-statement.js +0 -40
  30. package/cjs/sql-objects/max-statement.js +0 -40
  31. package/cjs/sql-objects/min-statement.js +0 -40
  32. package/cjs/sql-objects/operator.js +0 -7
  33. package/cjs/sql-objects/operators/comp-operator.js +0 -89
  34. package/cjs/sql-objects/operators/logical-operator.js +0 -86
  35. package/cjs/sql-objects/operators/op-and.js +0 -9
  36. package/cjs/sql-objects/operators/op-between.js +0 -40
  37. package/cjs/sql-objects/operators/op-eq.js +0 -13
  38. package/cjs/sql-objects/operators/op-exists.js +0 -31
  39. package/cjs/sql-objects/operators/op-gt.js +0 -13
  40. package/cjs/sql-objects/operators/op-gte.js +0 -13
  41. package/cjs/sql-objects/operators/op-ilike.js +0 -10
  42. package/cjs/sql-objects/operators/op-in.js +0 -19
  43. package/cjs/sql-objects/operators/op-is-not.js +0 -13
  44. package/cjs/sql-objects/operators/op-is.js +0 -13
  45. package/cjs/sql-objects/operators/op-like.js +0 -20
  46. package/cjs/sql-objects/operators/op-lt.js +0 -13
  47. package/cjs/sql-objects/operators/op-lte.js +0 -13
  48. package/cjs/sql-objects/operators/op-ne.js +0 -13
  49. package/cjs/sql-objects/operators/op-not-between.js +0 -10
  50. package/cjs/sql-objects/operators/op-not-exists.js +0 -10
  51. package/cjs/sql-objects/operators/op-not-ilike.js +0 -10
  52. package/cjs/sql-objects/operators/op-not-in.js +0 -10
  53. package/cjs/sql-objects/operators/op-not-like.js +0 -10
  54. package/cjs/sql-objects/operators/op-not.js +0 -21
  55. package/cjs/sql-objects/operators/op-or.js +0 -9
  56. package/cjs/sql-objects/order-column.js +0 -43
  57. package/cjs/sql-objects/param-expression.js +0 -56
  58. package/cjs/sql-objects/raw-statement.js +0 -19
  59. package/cjs/sql-objects/returning-column.js +0 -31
  60. package/cjs/sql-objects/sequence-getter-statement.js +0 -54
  61. package/cjs/sql-objects/string-agg-statement.js +0 -88
  62. package/cjs/sql-objects/table-name.js +0 -35
  63. package/cjs/sql-objects/upper-statement.js +0 -40
  64. package/cjs/sqlobject.initializers.js +0 -141
  65. package/cjs/typeguards.js +0 -85
  66. package/cjs/types.js +0 -2
  67. package/esm/package.json +0 -3
  68. package/types/index.d.cts +0 -20
  69. /package/{types/classes.ns.d.ts → classes.ns.d.ts} +0 -0
  70. /package/{esm/classes.ns.js → classes.ns.js} +0 -0
  71. /package/{types/enums.d.ts → enums.d.ts} +0 -0
  72. /package/{esm/enums.js → enums.js} +0 -0
  73. /package/{types/extensions.d.ts → extensions.d.ts} +0 -0
  74. /package/{esm/extensions.js → extensions.js} +0 -0
  75. /package/{types/helpers.d.ts → helpers.d.ts} +0 -0
  76. /package/{esm/helpers.js → helpers.js} +0 -0
  77. /package/{types/index.d.ts → index.d.ts} +0 -0
  78. /package/{esm/index.js → index.js} +0 -0
  79. /package/{types/op.initializers.d.ts → op.initializers.d.ts} +0 -0
  80. /package/{esm/op.initializers.js → op.initializers.js} +0 -0
  81. /package/{types/query → query}/delete-query.d.ts +0 -0
  82. /package/{esm/query → query}/delete-query.js +0 -0
  83. /package/{types/query → query}/insert-query.d.ts +0 -0
  84. /package/{esm/query → query}/insert-query.js +0 -0
  85. /package/{types/query → query}/query.d.ts +0 -0
  86. /package/{esm/query → query}/query.js +0 -0
  87. /package/{types/query → query}/returning-query.d.ts +0 -0
  88. /package/{esm/query → query}/returning-query.js +0 -0
  89. /package/{types/query → query}/select-query.d.ts +0 -0
  90. /package/{esm/query → query}/select-query.js +0 -0
  91. /package/{types/query → query}/union-query.d.ts +0 -0
  92. /package/{esm/query → query}/union-query.js +0 -0
  93. /package/{types/query → query}/update-query.d.ts +0 -0
  94. /package/{esm/query → query}/update-query.js +0 -0
  95. /package/{types/serializable.d.ts → serializable.d.ts} +0 -0
  96. /package/{esm/serializable.js → serializable.js} +0 -0
  97. /package/{types/serialize-context.d.ts → serialize-context.d.ts} +0 -0
  98. /package/{esm/serialize-context.js → serialize-context.js} +0 -0
  99. /package/{types/sql-objects → sql-objects}/base-field.d.ts +0 -0
  100. /package/{esm/sql-objects → sql-objects}/base-field.js +0 -0
  101. /package/{types/sql-objects → sql-objects}/case-statement.d.ts +0 -0
  102. /package/{esm/sql-objects → sql-objects}/case-statement.js +0 -0
  103. /package/{types/sql-objects → sql-objects}/coalesce-statement.d.ts +0 -0
  104. /package/{esm/sql-objects → sql-objects}/coalesce-statement.js +0 -0
  105. /package/{types/sql-objects → sql-objects}/count-statement.d.ts +0 -0
  106. /package/{esm/sql-objects → sql-objects}/count-statement.js +0 -0
  107. /package/{types/sql-objects → sql-objects}/expression.d.ts +0 -0
  108. /package/{esm/sql-objects → sql-objects}/expression.js +0 -0
  109. /package/{types/sql-objects → sql-objects}/field-expression.d.ts +0 -0
  110. /package/{esm/sql-objects → sql-objects}/field-expression.js +0 -0
  111. /package/{types/sql-objects → sql-objects}/group-column.d.ts +0 -0
  112. /package/{esm/sql-objects → sql-objects}/group-column.js +0 -0
  113. /package/{esm/sql-objects → sql-objects}/join-statement.js +0 -0
  114. /package/{types/sql-objects → sql-objects}/lower-statement.d.ts +0 -0
  115. /package/{esm/sql-objects → sql-objects}/lower-statement.js +0 -0
  116. /package/{types/sql-objects → sql-objects}/max-statement.d.ts +0 -0
  117. /package/{esm/sql-objects → sql-objects}/max-statement.js +0 -0
  118. /package/{types/sql-objects → sql-objects}/min-statement.d.ts +0 -0
  119. /package/{esm/sql-objects → sql-objects}/min-statement.js +0 -0
  120. /package/{types/sql-objects → sql-objects}/operator.d.ts +0 -0
  121. /package/{esm/sql-objects → sql-objects}/operator.js +0 -0
  122. /package/{types/sql-objects → sql-objects}/operators/comp-operator.d.ts +0 -0
  123. /package/{esm/sql-objects → sql-objects}/operators/comp-operator.js +0 -0
  124. /package/{types/sql-objects → sql-objects}/operators/logical-operator.d.ts +0 -0
  125. /package/{esm/sql-objects → sql-objects}/operators/logical-operator.js +0 -0
  126. /package/{types/sql-objects → sql-objects}/operators/op-and.d.ts +0 -0
  127. /package/{esm/sql-objects → sql-objects}/operators/op-and.js +0 -0
  128. /package/{types/sql-objects → sql-objects}/operators/op-between.d.ts +0 -0
  129. /package/{esm/sql-objects → sql-objects}/operators/op-between.js +0 -0
  130. /package/{types/sql-objects → sql-objects}/operators/op-eq.d.ts +0 -0
  131. /package/{esm/sql-objects → sql-objects}/operators/op-eq.js +0 -0
  132. /package/{types/sql-objects → sql-objects}/operators/op-exists.d.ts +0 -0
  133. /package/{esm/sql-objects → sql-objects}/operators/op-exists.js +0 -0
  134. /package/{types/sql-objects → sql-objects}/operators/op-gt.d.ts +0 -0
  135. /package/{esm/sql-objects → sql-objects}/operators/op-gt.js +0 -0
  136. /package/{types/sql-objects → sql-objects}/operators/op-gte.d.ts +0 -0
  137. /package/{esm/sql-objects → sql-objects}/operators/op-gte.js +0 -0
  138. /package/{types/sql-objects → sql-objects}/operators/op-ilike.d.ts +0 -0
  139. /package/{esm/sql-objects → sql-objects}/operators/op-ilike.js +0 -0
  140. /package/{types/sql-objects → sql-objects}/operators/op-in.d.ts +0 -0
  141. /package/{esm/sql-objects → sql-objects}/operators/op-in.js +0 -0
  142. /package/{types/sql-objects → sql-objects}/operators/op-is-not.d.ts +0 -0
  143. /package/{esm/sql-objects → sql-objects}/operators/op-is-not.js +0 -0
  144. /package/{types/sql-objects → sql-objects}/operators/op-is.d.ts +0 -0
  145. /package/{esm/sql-objects → sql-objects}/operators/op-is.js +0 -0
  146. /package/{types/sql-objects → sql-objects}/operators/op-like.d.ts +0 -0
  147. /package/{esm/sql-objects → sql-objects}/operators/op-like.js +0 -0
  148. /package/{types/sql-objects → sql-objects}/operators/op-lt.d.ts +0 -0
  149. /package/{esm/sql-objects → sql-objects}/operators/op-lt.js +0 -0
  150. /package/{types/sql-objects → sql-objects}/operators/op-lte.d.ts +0 -0
  151. /package/{esm/sql-objects → sql-objects}/operators/op-lte.js +0 -0
  152. /package/{types/sql-objects → sql-objects}/operators/op-ne.d.ts +0 -0
  153. /package/{esm/sql-objects → sql-objects}/operators/op-ne.js +0 -0
  154. /package/{types/sql-objects → sql-objects}/operators/op-not-between.d.ts +0 -0
  155. /package/{esm/sql-objects → sql-objects}/operators/op-not-between.js +0 -0
  156. /package/{types/sql-objects → sql-objects}/operators/op-not-exists.d.ts +0 -0
  157. /package/{esm/sql-objects → sql-objects}/operators/op-not-exists.js +0 -0
  158. /package/{types/sql-objects → sql-objects}/operators/op-not-ilike.d.ts +0 -0
  159. /package/{esm/sql-objects → sql-objects}/operators/op-not-ilike.js +0 -0
  160. /package/{types/sql-objects → sql-objects}/operators/op-not-in.d.ts +0 -0
  161. /package/{esm/sql-objects → sql-objects}/operators/op-not-in.js +0 -0
  162. /package/{types/sql-objects → sql-objects}/operators/op-not-like.d.ts +0 -0
  163. /package/{esm/sql-objects → sql-objects}/operators/op-not-like.js +0 -0
  164. /package/{types/sql-objects → sql-objects}/operators/op-not.d.ts +0 -0
  165. /package/{esm/sql-objects → sql-objects}/operators/op-not.js +0 -0
  166. /package/{types/sql-objects → sql-objects}/operators/op-or.d.ts +0 -0
  167. /package/{esm/sql-objects → sql-objects}/operators/op-or.js +0 -0
  168. /package/{types/sql-objects → sql-objects}/order-column.d.ts +0 -0
  169. /package/{esm/sql-objects → sql-objects}/order-column.js +0 -0
  170. /package/{types/sql-objects → sql-objects}/param-expression.d.ts +0 -0
  171. /package/{esm/sql-objects → sql-objects}/param-expression.js +0 -0
  172. /package/{types/sql-objects → sql-objects}/raw-statement.d.ts +0 -0
  173. /package/{esm/sql-objects → sql-objects}/raw-statement.js +0 -0
  174. /package/{types/sql-objects → sql-objects}/returning-column.d.ts +0 -0
  175. /package/{esm/sql-objects → sql-objects}/returning-column.js +0 -0
  176. /package/{types/sql-objects → sql-objects}/sequence-getter-statement.d.ts +0 -0
  177. /package/{esm/sql-objects → sql-objects}/sequence-getter-statement.js +0 -0
  178. /package/{types/sql-objects → sql-objects}/string-agg-statement.d.ts +0 -0
  179. /package/{esm/sql-objects → sql-objects}/string-agg-statement.js +0 -0
  180. /package/{types/sql-objects → sql-objects}/table-name.d.ts +0 -0
  181. /package/{esm/sql-objects → sql-objects}/table-name.js +0 -0
  182. /package/{types/sql-objects → sql-objects}/upper-statement.d.ts +0 -0
  183. /package/{esm/sql-objects → sql-objects}/upper-statement.js +0 -0
  184. /package/{types/sqlobject.initializers.d.ts → sqlobject.initializers.d.ts} +0 -0
  185. /package/{esm/sqlobject.initializers.js → sqlobject.initializers.js} +0 -0
  186. /package/{types/types.d.ts → types.d.ts} +0 -0
  187. /package/{esm/types.js → types.js} +0 -0
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@sqb/builder",
3
3
  "description": "Extensible multi-dialect SQL query builder written with TypeScript",
4
- "version": "4.20.7",
4
+ "version": "4.21.1",
5
5
  "author": "Panates",
6
6
  "license": "Apache-2.0",
7
7
  "dependencies": {
@@ -13,23 +13,18 @@
13
13
  "tslib": "^2.8.1"
14
14
  },
15
15
  "type": "module",
16
+ "module": "./index.js",
17
+ "types": "./index.d.ts",
16
18
  "exports": {
17
19
  ".": {
18
- "import": {
19
- "types": "./types/index.d.ts",
20
- "default": "./esm/index.js"
21
- },
22
- "require": {
23
- "types": "./types/index.d.cts",
24
- "default": "./cjs/index.js"
25
- },
26
- "default": "./esm/index.js"
20
+ "types": "./index.d.ts",
21
+ "default": "./index.js"
27
22
  },
28
23
  "./package.json": "./package.json"
29
24
  },
30
- "main": "./cjs/index.js",
31
- "module": "./esm/index.js",
32
- "types": "./types/index.d.ts",
25
+ "engines": {
26
+ "node": ">=20.0"
27
+ },
33
28
  "contributors": [
34
29
  "Eray Hanoglu <e.hanoglu@panates.com>",
35
30
  "Ilker Gurelli <i.gurelli@panates.com>"
@@ -39,17 +34,6 @@
39
34
  "url": "https://github.com/panates/sqb.git",
40
35
  "directory": "packages/builder"
41
36
  },
42
- "engines": {
43
- "node": ">=18.0"
44
- },
45
- "files": [
46
- "bin/",
47
- "cjs/",
48
- "esm/",
49
- "types/",
50
- "LICENSE",
51
- "README.md"
52
- ],
53
37
  "keywords": [
54
38
  "javascript",
55
39
  "typescript",
@@ -1,9 +1,9 @@
1
1
  import { JoinType, SerializationType } from '../enums.js';
2
- import { SelectQuery } from '../query/select-query.js';
2
+ import type { SelectQuery } from '../query/select-query.js';
3
3
  import { Serializable } from '../serializable.js';
4
- import { SerializeContext } from '../serialize-context.js';
5
- import { LogicalOperator } from './operators/logical-operator.js';
6
- import { RawStatement } from './raw-statement.js';
4
+ import type { SerializeContext } from '../serialize-context.js';
5
+ import type { LogicalOperator } from './operators/logical-operator.js';
6
+ import type { RawStatement } from './raw-statement.js';
7
7
  import { TableName } from './table-name.js';
8
8
  export declare class JoinStatement extends Serializable {
9
9
  _joinType: JoinType;
@@ -1,10 +1,11 @@
1
1
  import type { DeleteQuery } from './query/delete-query.js';
2
2
  import type { InsertQuery } from './query/insert-query.js';
3
+ import type { Query } from './query/query.js';
3
4
  import type { SelectQuery } from './query/select-query.js';
4
5
  import type { UpdateQuery } from './query/update-query.js';
5
- import { Serializable } from './serializable.js';
6
+ import type { Serializable } from './serializable.js';
6
7
  import type { CaseStatement } from './sql-objects/case-statement.js';
7
- import { CountStatement } from './sql-objects/count-statement.js';
8
+ import type { CountStatement } from './sql-objects/count-statement.js';
8
9
  import type { FieldExpression } from './sql-objects/field-expression.js';
9
10
  import type { GroupColumn } from './sql-objects/group-column.js';
10
11
  import type { JoinStatement } from './sql-objects/join-statement.js';
@@ -16,7 +17,7 @@ import type { RawStatement } from './sql-objects/raw-statement.js';
16
17
  import type { ReturningColumn } from './sql-objects/returning-column.js';
17
18
  import type { TableName } from './sql-objects/table-name.js';
18
19
  export declare function isSerializable(value: any): value is Serializable;
19
- export declare function isQuery(value: any): value is Serializable;
20
+ export declare function isQuery(value: any): value is Query;
20
21
  export declare function isRawStatement(value: any): value is RawStatement;
21
22
  export declare function isSelectQuery(value: any): value is SelectQuery;
22
23
  export declare function isInsertQuery(value: any): value is InsertQuery;
@@ -1,11 +1,11 @@
1
1
  import { SerializationType } from './enums.js';
2
- import { Query } from './query/query.js';
3
- import { Serializable } from './serializable.js';
4
2
  export function isSerializable(value) {
5
- return value instanceof Serializable;
3
+ return typeof value === 'object' && typeof value._serialize === 'function';
6
4
  }
7
5
  export function isQuery(value) {
8
- return value instanceof Query;
6
+ return (isSerializable(value) &&
7
+ typeof value.generate === 'function' &&
8
+ typeof value.values === 'function');
9
9
  }
10
10
  export function isRawStatement(value) {
11
11
  return isSerializable(value) && value._type === SerializationType.RAW;
package/cjs/classes.ns.js DELETED
@@ -1,41 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const tslib_1 = require("tslib");
4
- tslib_1.__exportStar(require("./query/delete-query.js"), exports);
5
- tslib_1.__exportStar(require("./query/insert-query.js"), exports);
6
- tslib_1.__exportStar(require("./query/query.js"), exports);
7
- tslib_1.__exportStar(require("./query/returning-query.js"), exports);
8
- tslib_1.__exportStar(require("./query/select-query.js"), exports);
9
- tslib_1.__exportStar(require("./query/update-query.js"), exports);
10
- tslib_1.__exportStar(require("./sql-objects/base-field.js"), exports);
11
- tslib_1.__exportStar(require("./sql-objects/case-statement.js"), exports);
12
- tslib_1.__exportStar(require("./sql-objects/count-statement.js"), exports);
13
- tslib_1.__exportStar(require("./sql-objects/field-expression.js"), exports);
14
- tslib_1.__exportStar(require("./sql-objects/group-column.js"), exports);
15
- tslib_1.__exportStar(require("./sql-objects/join-statement.js"), exports);
16
- tslib_1.__exportStar(require("./sql-objects/operator.js"), exports);
17
- tslib_1.__exportStar(require("./sql-objects/operators/comp-operator.js"), exports);
18
- tslib_1.__exportStar(require("./sql-objects/operators/logical-operator.js"), exports);
19
- tslib_1.__exportStar(require("./sql-objects/operators/op-and.js"), exports);
20
- tslib_1.__exportStar(require("./sql-objects/operators/op-between.js"), exports);
21
- tslib_1.__exportStar(require("./sql-objects/operators/op-eq.js"), exports);
22
- tslib_1.__exportStar(require("./sql-objects/operators/op-exists.js"), exports);
23
- tslib_1.__exportStar(require("./sql-objects/operators/op-gt.js"), exports);
24
- tslib_1.__exportStar(require("./sql-objects/operators/op-gte.js"), exports);
25
- tslib_1.__exportStar(require("./sql-objects/operators/op-ilike.js"), exports);
26
- tslib_1.__exportStar(require("./sql-objects/operators/op-in.js"), exports);
27
- tslib_1.__exportStar(require("./sql-objects/operators/op-is.js"), exports);
28
- tslib_1.__exportStar(require("./sql-objects/operators/op-is-not.js"), exports);
29
- tslib_1.__exportStar(require("./sql-objects/operators/op-like.js"), exports);
30
- tslib_1.__exportStar(require("./sql-objects/operators/op-lt.js"), exports);
31
- tslib_1.__exportStar(require("./sql-objects/operators/op-lte.js"), exports);
32
- tslib_1.__exportStar(require("./sql-objects/operators/op-ne.js"), exports);
33
- tslib_1.__exportStar(require("./sql-objects/operators/op-not-between.js"), exports);
34
- tslib_1.__exportStar(require("./sql-objects/operators/op-not-exists.js"), exports);
35
- tslib_1.__exportStar(require("./sql-objects/operators/op-not-ilike.js"), exports);
36
- tslib_1.__exportStar(require("./sql-objects/operators/op-not-in.js"), exports);
37
- tslib_1.__exportStar(require("./sql-objects/operators/op-not-like.js"), exports);
38
- tslib_1.__exportStar(require("./sql-objects/operators/op-or.js"), exports);
39
- tslib_1.__exportStar(require("./sql-objects/order-column.js"), exports);
40
- tslib_1.__exportStar(require("./sql-objects/raw-statement.js"), exports);
41
- tslib_1.__exportStar(require("./sql-objects/table-name.js"), exports);
package/cjs/enums.js DELETED
@@ -1,102 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DataType = exports.OperatorType = exports.SerializationType = exports.JoinType = void 0;
4
- var JoinType;
5
- (function (JoinType) {
6
- JoinType["INNER"] = "inner";
7
- JoinType["LEFT"] = "left";
8
- JoinType["LEFT_OUTER"] = "left outer";
9
- JoinType["RIGHT"] = "right";
10
- JoinType["RIGHT_OUTER"] = "right outer";
11
- JoinType["OUTER"] = "outer";
12
- JoinType["FULL_OUTER"] = "full outer";
13
- JoinType["CROSS"] = "cross";
14
- })(JoinType || (exports.JoinType = JoinType = {}));
15
- var SerializationType;
16
- (function (SerializationType) {
17
- SerializationType["SELECT_QUERY"] = "select_query";
18
- SerializationType["SELECT_QUERY_COLUMNS"] = "select_query.columns";
19
- SerializationType["SELECT_QUERY_FROM"] = "select_query.from";
20
- SerializationType["SELECT_QUERY_JOIN"] = "select_query.join";
21
- SerializationType["SELECT_QUERY_GROUPBY"] = "select_query.groupby";
22
- SerializationType["SELECT_QUERY_ORDERBY"] = "select_query.orderby";
23
- SerializationType["INSERT_QUERY"] = "insert_query";
24
- SerializationType["INSERT_QUERY_COLUMNS"] = "insert_query.columns";
25
- SerializationType["INSERT_QUERY_VALUES"] = "insert_query.values";
26
- SerializationType["UPDATE_QUERY"] = "update_query";
27
- SerializationType["UPDATE_QUERY_VALUES"] = "update_query.values";
28
- SerializationType["DELETE_QUERY"] = "delete_query";
29
- SerializationType["UNION_QUERY"] = "union_query";
30
- SerializationType["FIELD_NAME"] = "field_name";
31
- SerializationType["GROUP_COLUMN"] = "group_column";
32
- SerializationType["ORDER_COLUMN"] = "order_column";
33
- SerializationType["RETURNING_COLUMN"] = "returning_column";
34
- SerializationType["TABLE_NAME"] = "table_name";
35
- SerializationType["JOIN"] = "join";
36
- SerializationType["JOIN_CONDITIONS"] = "join_conditions";
37
- SerializationType["RAW"] = "raw";
38
- SerializationType["CASE_STATEMENT"] = "case_expression";
39
- SerializationType["COALESCE_STATEMENT"] = "coalesce_expression";
40
- SerializationType["LOWER_STATEMENT"] = "lower_expression";
41
- SerializationType["UPPER_STATEMENT"] = "upper_expression";
42
- SerializationType["MAX_STATEMENT"] = "max_expression";
43
- SerializationType["MIN_STATEMENT"] = "min_expression";
44
- SerializationType["COUNT_STATEMENT"] = "count_expression";
45
- SerializationType["CONDITIONS_BLOCK"] = "conditions_block";
46
- SerializationType["COMPARISON_EXPRESSION"] = "comparison_expression";
47
- SerializationType["LOGICAL_EXPRESSION"] = "logical_expression";
48
- SerializationType["NEGATIVE_EXPRESSION"] = "negative_expression";
49
- SerializationType["RETURNING_BLOCK"] = "returning_block";
50
- SerializationType["DATE_VALUE"] = "date_value";
51
- SerializationType["STRING_VALUE"] = "string_value";
52
- SerializationType["BOOLEAN_VALUE"] = "boolean_value";
53
- SerializationType["NUMBER_VALUE"] = "number_value";
54
- SerializationType["EXTERNAL_PARAMETER"] = "external_parameter";
55
- SerializationType["ARRAY"] = "array";
56
- SerializationType["SEQUENCE_GETTER_STATEMENT"] = "sequence_getter_statement";
57
- SerializationType["STRINGAGG_STATEMENT"] = "String_agg_statement";
58
- })(SerializationType || (exports.SerializationType = SerializationType = {}));
59
- var OperatorType;
60
- (function (OperatorType) {
61
- OperatorType["and"] = "and";
62
- OperatorType["or"] = "or";
63
- OperatorType["eq"] = "eq";
64
- OperatorType["ne"] = "ne";
65
- OperatorType["gt"] = "gt";
66
- OperatorType["gte"] = "gte";
67
- OperatorType["lt"] = "lt";
68
- OperatorType["lte"] = "lte";
69
- OperatorType["between"] = "between";
70
- OperatorType["notBetween"] = "notBetween";
71
- OperatorType["in"] = "in";
72
- OperatorType["notIn"] = "notIn";
73
- OperatorType["like"] = "like";
74
- OperatorType["notLike"] = "notLike";
75
- OperatorType["iLike"] = "iLike";
76
- OperatorType["notILike"] = "notILike";
77
- OperatorType["is"] = "is";
78
- OperatorType["isNot"] = "isNot";
79
- OperatorType["exists"] = "exists";
80
- OperatorType["notExists"] = "notExists";
81
- OperatorType["not"] = "not";
82
- })(OperatorType || (exports.OperatorType = OperatorType = {}));
83
- var DataType;
84
- (function (DataType) {
85
- DataType["BOOL"] = "BOOL";
86
- DataType["CHAR"] = "CHAR";
87
- DataType["VARCHAR"] = "VARCHAR";
88
- DataType["SMALLINT"] = "SMALLINT";
89
- DataType["INTEGER"] = "INTEGER";
90
- DataType["BIGINT"] = "BIGINT";
91
- DataType["FLOAT"] = "FLOAT";
92
- DataType["DOUBLE"] = "DOUBLE";
93
- DataType["NUMBER"] = "NUMBER";
94
- DataType["DATE"] = "DATE";
95
- DataType["TIMESTAMP"] = "TIMESTAMP";
96
- DataType["TIMESTAMPTZ"] = "TIMESTAMPTZ";
97
- DataType["TIME"] = "TIME";
98
- DataType["BINARY"] = "BINARY";
99
- DataType["TEXT"] = "TEXT";
100
- DataType["GUID"] = "GUID";
101
- DataType["JSON"] = "JSON";
102
- })(DataType || (exports.DataType = DataType = {}));
package/cjs/extensions.js DELETED
@@ -1,38 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SerializerRegistry = void 0;
4
- class SerializerRegistry {
5
- static serializers = [];
6
- static get size() {
7
- return this.serializers.length;
8
- }
9
- static register(...extension) {
10
- for (const ext of extension) {
11
- if (!ext.dialect)
12
- throw new TypeError('A SerializerExtension must contain "dialect" property');
13
- this.serializers.push(ext);
14
- }
15
- }
16
- static forEach(callback, thisArg) {
17
- return this.serializers.forEach(callback, thisArg);
18
- }
19
- static items() {
20
- return this.serializers.values();
21
- }
22
- static unRegister(...extensions) {
23
- this.serializers = this.serializers.filter(x => !extensions.includes(x));
24
- }
25
- static getAll(dialect) {
26
- return this.serializers.filter(x => x.dialect === dialect);
27
- }
28
- static get(index) {
29
- return this.serializers[index];
30
- }
31
- static findDialect(dialect) {
32
- return this.serializers.find(x => x.dialect === dialect);
33
- }
34
- static has(extension) {
35
- return !!this.serializers.find(x => x === extension);
36
- }
37
- }
38
- exports.SerializerRegistry = SerializerRegistry;
package/cjs/helpers.js DELETED
@@ -1,30 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.printArray = printArray;
4
- /**
5
- * Prints array with line feeding
6
- */
7
- function printArray(arr, sep, lfLen) {
8
- let out = '';
9
- let line = '';
10
- let k = 0;
11
- lfLen = lfLen || 60;
12
- sep = sep || ',';
13
- for (const s of arr) {
14
- /* istanbul ignore next */
15
- if (s === undefined)
16
- continue;
17
- line += k > 0 ? sep : '';
18
- if (line.length > lfLen) {
19
- out += (out ? '\n' : '') + line;
20
- line = '';
21
- }
22
- else
23
- line += line ? ' ' : '';
24
- line += s;
25
- k++;
26
- }
27
- if (line)
28
- out += (out ? '\n' : '') + line;
29
- return out;
30
- }
package/cjs/index.js DELETED
@@ -1,25 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.op = exports.classes = void 0;
4
- const tslib_1 = require("tslib");
5
- exports.classes = tslib_1.__importStar(require("./classes.ns.js"));
6
- tslib_1.__exportStar(require("./enums.js"), exports);
7
- tslib_1.__exportStar(require("./extensions.js"), exports);
8
- tslib_1.__exportStar(require("./helpers.js"), exports);
9
- tslib_1.__exportStar(require("./op.initializers.js"), exports);
10
- var op_initializers_js_1 = require("./op.initializers.js");
11
- Object.defineProperty(exports, "op", { enumerable: true, get: function () { return op_initializers_js_1.op; } });
12
- tslib_1.__exportStar(require("./query/delete-query.js"), exports);
13
- tslib_1.__exportStar(require("./query/insert-query.js"), exports);
14
- tslib_1.__exportStar(require("./query/query.js"), exports);
15
- tslib_1.__exportStar(require("./query/select-query.js"), exports);
16
- tslib_1.__exportStar(require("./query/update-query.js"), exports);
17
- tslib_1.__exportStar(require("./serializable.js"), exports);
18
- tslib_1.__exportStar(require("./serialize-context.js"), exports);
19
- tslib_1.__exportStar(require("./sql-objects/join-statement.js"), exports);
20
- tslib_1.__exportStar(require("./sql-objects/operator.js"), exports);
21
- tslib_1.__exportStar(require("./sql-objects/operators/comp-operator.js"), exports);
22
- tslib_1.__exportStar(require("./sql-objects/operators/logical-operator.js"), exports);
23
- tslib_1.__exportStar(require("./sqlobject.initializers.js"), exports);
24
- tslib_1.__exportStar(require("./typeguards.js"), exports);
25
- tslib_1.__exportStar(require("./types.js"), exports);
@@ -1,163 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.op = void 0;
4
- exports.And = And;
5
- exports.Between = Between;
6
- exports.Eq = Eq;
7
- exports.Equal = Eq;
8
- exports.Exists = Exists;
9
- exports.GreaterAnEqualTo = Gte;
10
- exports.Gte = Gte;
11
- exports.GreaterThan = Gt;
12
- exports.Gt = Gt;
13
- exports.Ilike = Ilike;
14
- exports.In = In;
15
- exports.Is = Is;
16
- exports.IsNot = IsNot;
17
- exports.Like = Like;
18
- exports.LowerAndEqualTo = Lte;
19
- exports.Lte = Lte;
20
- exports.LowerThan = Lt;
21
- exports.Lt = Lt;
22
- exports.Ne = Ne;
23
- exports.NotEqual = Ne;
24
- exports.Nilike = NotILike;
25
- exports.NotILike = NotILike;
26
- exports.Nin = NotIn;
27
- exports.NotIn = NotIn;
28
- exports.NLike = NotLike;
29
- exports.NotLike = NotLike;
30
- exports.Not = Not;
31
- exports.NotBetween = NotBetween;
32
- exports.NotExists = NotExists;
33
- exports.Or = Or;
34
- const logical_operator_js_1 = require("./sql-objects/operators/logical-operator.js");
35
- const op_and_js_1 = require("./sql-objects/operators/op-and.js");
36
- const op_between_js_1 = require("./sql-objects/operators/op-between.js");
37
- const op_eq_js_1 = require("./sql-objects/operators/op-eq.js");
38
- const op_exists_js_1 = require("./sql-objects/operators/op-exists.js");
39
- const op_gt_js_1 = require("./sql-objects/operators/op-gt.js");
40
- const op_gte_js_1 = require("./sql-objects/operators/op-gte.js");
41
- const op_ilike_js_1 = require("./sql-objects/operators/op-ilike.js");
42
- const op_in_js_1 = require("./sql-objects/operators/op-in.js");
43
- const op_is_js_1 = require("./sql-objects/operators/op-is.js");
44
- const op_is_not_js_1 = require("./sql-objects/operators/op-is-not.js");
45
- const op_like_js_1 = require("./sql-objects/operators/op-like.js");
46
- const op_lt_js_1 = require("./sql-objects/operators/op-lt.js");
47
- const op_lte_js_1 = require("./sql-objects/operators/op-lte.js");
48
- const op_ne_js_1 = require("./sql-objects/operators/op-ne.js");
49
- const op_not_js_1 = require("./sql-objects/operators/op-not.js");
50
- const op_not_between_js_1 = require("./sql-objects/operators/op-not-between.js");
51
- const op_not_exists_js_1 = require("./sql-objects/operators/op-not-exists.js");
52
- const op_not_ilike_js_1 = require("./sql-objects/operators/op-not-ilike.js");
53
- const op_not_in_js_1 = require("./sql-objects/operators/op-not-in.js");
54
- const op_not_like_js_1 = require("./sql-objects/operators/op-not-like.js");
55
- const op_or_js_1 = require("./sql-objects/operators/op-or.js");
56
- function And(...args) {
57
- return new op_and_js_1.OpAnd(...args);
58
- }
59
- function Or(...args) {
60
- return new op_or_js_1.OpOr(...args);
61
- }
62
- function Eq(expression, value) {
63
- return new op_eq_js_1.OpEq(expression, value);
64
- }
65
- function Ne(expression, value) {
66
- return new op_ne_js_1.OpNe(expression, value);
67
- }
68
- function Gt(expression, value) {
69
- return new op_gt_js_1.OpGt(expression, value);
70
- }
71
- function Gte(expression, value) {
72
- return new op_gte_js_1.OpGte(expression, value);
73
- }
74
- function Lt(expression, value) {
75
- return new op_lt_js_1.OpLt(expression, value);
76
- }
77
- function Lte(expression, value) {
78
- return new op_lte_js_1.OpLte(expression, value);
79
- }
80
- function Between(expression, value1, value2) {
81
- const values = Array.isArray(value1) ? value1 : [value1, value2];
82
- return new op_between_js_1.OpBetween(expression, values);
83
- }
84
- function NotBetween(expression, value1, value2) {
85
- const values = Array.isArray(value1) ? value1 : [value1, value2];
86
- return new op_not_between_js_1.OpNotBetween(expression, values);
87
- }
88
- function In(expression, value) {
89
- return new op_in_js_1.OpIn(expression, value);
90
- }
91
- function NotIn(expression, value) {
92
- return new op_not_in_js_1.OpNotIn(expression, value);
93
- }
94
- function Like(expression, value) {
95
- return new op_like_js_1.OpLike(expression, value);
96
- }
97
- function NotLike(expression, value) {
98
- return new op_not_like_js_1.OpNotLike(expression, value);
99
- }
100
- function Ilike(expression, value) {
101
- return new op_ilike_js_1.OpILike(expression, value);
102
- }
103
- function NotILike(expression, value) {
104
- return new op_not_ilike_js_1.OpNotILike(expression, value);
105
- }
106
- function Is(expression, value) {
107
- return new op_is_js_1.OpIs(expression, value);
108
- }
109
- function IsNot(expression, value) {
110
- return new op_is_not_js_1.OpIsNot(expression, value);
111
- }
112
- function Exists(expression) {
113
- return new op_exists_js_1.OpExists(expression);
114
- }
115
- function NotExists(expression) {
116
- return new op_not_exists_js_1.OpNotExists(expression);
117
- }
118
- function Not(expression) {
119
- return new op_not_js_1.OpNot(expression);
120
- }
121
- const op = {
122
- and: And,
123
- or: Or,
124
- eq: Eq,
125
- '=': Eq,
126
- ne: Ne,
127
- '!=': Ne,
128
- gt: Gt,
129
- '>': Gt,
130
- gte: Gte,
131
- '>=': Gte,
132
- lt: Lt,
133
- '<': Lt,
134
- lte: Lte,
135
- '<=': Lte,
136
- between: Between,
137
- btw: Between,
138
- notBetween: NotBetween,
139
- nbtw: NotBetween,
140
- '!between': NotBetween,
141
- '!btw': NotBetween,
142
- in: In,
143
- notIn: NotIn,
144
- nin: NotIn,
145
- '!in': NotIn,
146
- like: Like,
147
- not: Not,
148
- notLike: NotLike,
149
- nlike: NotLike,
150
- '!like': NotLike,
151
- ilike: Ilike,
152
- notILike: NotILike,
153
- nilike: NotILike,
154
- '!ilike': NotILike,
155
- is: Is,
156
- isNot: IsNot,
157
- '!is': IsNot,
158
- exists: Exists,
159
- notExists: NotExists,
160
- '!exists': NotExists,
161
- };
162
- exports.op = op;
163
- Object.assign(logical_operator_js_1.WrapOps, op);
package/cjs/package.json DELETED
@@ -1,3 +0,0 @@
1
- {
2
- "type": "commonjs"
3
- }
@@ -1,57 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DeleteQuery = void 0;
4
- const enums_js_1 = require("../enums.js");
5
- const op_and_js_1 = require("../sql-objects/operators/op-and.js");
6
- const table_name_js_1 = require("../sql-objects/table-name.js");
7
- const typeguards_js_1 = require("../typeguards.js");
8
- const query_js_1 = require("./query.js");
9
- class DeleteQuery extends query_js_1.Query {
10
- _table;
11
- _where;
12
- constructor(tableName) {
13
- super();
14
- if (!tableName ||
15
- !(typeof tableName === 'string' || (0, typeguards_js_1.isRawStatement)(tableName))) {
16
- throw new TypeError('String or Raw instance required as first argument (tableName) for UpdateQuery');
17
- }
18
- this._table =
19
- typeof tableName === 'string' ? new table_name_js_1.TableName(tableName) : tableName;
20
- }
21
- get _type() {
22
- return enums_js_1.SerializationType.DELETE_QUERY;
23
- }
24
- /**
25
- * Defines "where" part of query
26
- */
27
- where(...operator) {
28
- this._where = this._where || new op_and_js_1.OpAnd();
29
- this._where.add(...operator);
30
- return this;
31
- }
32
- /**
33
- * Performs serialization
34
- */
35
- _serialize(ctx) {
36
- const o = {
37
- table: this._table._serialize(ctx),
38
- where: this._serializeWhere(ctx),
39
- };
40
- return ctx.serialize(this._type, o, () => this.__defaultSerialize(ctx, o));
41
- }
42
- __defaultSerialize(ctx, o) {
43
- return 'delete from ' + o.table + (o.where ? '\n' + o.where : '');
44
- }
45
- /**
46
- *
47
- */
48
- _serializeWhere(ctx) {
49
- if (!this._where)
50
- return '';
51
- const s = this._where._serialize(ctx);
52
- return ctx.serialize(enums_js_1.SerializationType.CONDITIONS_BLOCK, s, () =>
53
- /* istanbul ignore next */
54
- s ? 'where ' + s : '');
55
- }
56
- }
57
- exports.DeleteQuery = DeleteQuery;
@@ -1,86 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InsertQuery = void 0;
4
- const enums_js_1 = require("../enums.js");
5
- const helpers_js_1 = require("../helpers.js");
6
- const table_name_js_1 = require("../sql-objects/table-name.js");
7
- const typeguards_js_1 = require("../typeguards.js");
8
- const returning_query_js_1 = require("./returning-query.js");
9
- class InsertQuery extends returning_query_js_1.ReturningQuery {
10
- _table;
11
- _input;
12
- constructor(tableName, input) {
13
- super();
14
- if (!tableName ||
15
- !(typeof tableName === 'string' || (0, typeguards_js_1.isRawStatement)(tableName))) {
16
- throw new TypeError('String or Raw instance required as first argument (tableName) for InsertQuery');
17
- }
18
- if (!input ||
19
- !((typeof input === 'object' && !Array.isArray(input)) || input.isSelect)) {
20
- throw new TypeError('Object or SelectQuery instance required as second argument (input) for InsertQuery');
21
- }
22
- this._table =
23
- typeof tableName === 'string' ? new table_name_js_1.TableName(tableName) : tableName;
24
- this._input = input;
25
- }
26
- get _type() {
27
- return enums_js_1.SerializationType.INSERT_QUERY;
28
- }
29
- /**
30
- * Performs serialization
31
- */
32
- _serialize(ctx) {
33
- const o = {
34
- table: this._table._serialize(ctx),
35
- columns: this.__serializeColumns(ctx),
36
- values: this.__serializeValues(ctx),
37
- returning: this.__serializeReturning(ctx),
38
- };
39
- let out = 'insert into ' +
40
- o.table +
41
- '\n\t(' +
42
- o.columns +
43
- ')\n\bvalues\n\t(' +
44
- o.values +
45
- ')\b';
46
- if (o.returning)
47
- out += '\n' + o.returning;
48
- return out;
49
- }
50
- /**
51
- *
52
- */
53
- __serializeColumns(ctx) {
54
- let arr;
55
- if ((0, typeguards_js_1.isSelectQuery)(this._input)) {
56
- arr = [];
57
- const cols = this._input._columns;
58
- if (cols) {
59
- for (const col of cols) {
60
- if (col._alias)
61
- arr.push(col._alias);
62
- else if (col._field)
63
- arr.push(col._field);
64
- }
65
- }
66
- }
67
- else
68
- arr = Object.keys(this._input);
69
- return ctx.serialize(enums_js_1.SerializationType.INSERT_QUERY_COLUMNS, arr, () => (0, helpers_js_1.printArray)(arr));
70
- }
71
- /**
72
- *
73
- */
74
- __serializeValues(ctx) {
75
- if ((0, typeguards_js_1.isSerializable)(this._input))
76
- return this._input._serialize(ctx);
77
- const arr = [];
78
- const allValues = this._input;
79
- for (const n of Object.keys(allValues)) {
80
- const s = ctx.anyToSQL(allValues[n]) || 'null';
81
- arr.push(s);
82
- }
83
- return ctx.serialize(enums_js_1.SerializationType.INSERT_QUERY_VALUES, arr, () => (0, helpers_js_1.printArray)(arr));
84
- }
85
- }
86
- exports.InsertQuery = InsertQuery;