af-db-ts 2.0.19 → 2.0.73
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/__tests__/db/ms/@gen-types/test-table_schema.js +3 -0
- package/dist/cjs/__tests__/db/ms/@gen-types/test-table_schema.js.map +1 -0
- package/dist/cjs/__tests__/db/ms/ddl/column-schema-for-test-table-schema-ms.json +216 -0
- package/dist/cjs/__tests__/db/ms/ms-get-sql.spec.js +190 -0
- package/dist/cjs/__tests__/db/ms/ms-get-sql.spec.js.map +1 -0
- package/dist/cjs/__tests__/db/ms/ms-prepare-sql-value.spec.js +584 -0
- package/dist/cjs/__tests__/db/ms/ms-prepare-sql-value.spec.js.map +1 -0
- package/dist/cjs/__tests__/db/ms/ms-table-schema.spec.js +107 -0
- package/dist/cjs/__tests__/db/ms/ms-table-schema.spec.js.map +1 -0
- package/dist/cjs/__tests__/db/pg/@gen-types/test-hard_case.js +3 -0
- package/dist/cjs/__tests__/db/pg/@gen-types/test-hard_case.js.map +1 -0
- package/dist/cjs/__tests__/db/pg/@gen-types/test-only_one_serial.js +3 -0
- package/dist/cjs/__tests__/db/pg/@gen-types/test-only_one_serial.js.map +1 -0
- package/dist/cjs/__tests__/db/pg/@gen-types/test-only_one_uniq.js +3 -0
- package/dist/cjs/__tests__/db/pg/@gen-types/test-only_one_uniq.js.map +1 -0
- package/dist/cjs/__tests__/db/pg/@gen-types/test-serial_and_uniq.js +3 -0
- package/dist/cjs/__tests__/db/pg/@gen-types/test-serial_and_uniq.js.map +1 -0
- package/dist/cjs/__tests__/db/pg/@gen-types/test-table_schema.js +3 -0
- package/dist/cjs/__tests__/db/pg/@gen-types/test-table_schema.js.map +1 -0
- package/dist/cjs/__tests__/db/pg/ddl/column-schema-for-test-table-schema-pg.json +170 -0
- package/dist/cjs/__tests__/db/pg/gen-table-interfaces-4-test-pg.js +36 -0
- package/dist/cjs/__tests__/db/pg/gen-table-interfaces-4-test-pg.js.map +1 -0
- package/dist/cjs/__tests__/db/pg/pg-get-sql.spec.js +261 -0
- package/dist/cjs/__tests__/db/pg/pg-get-sql.spec.js.map +1 -0
- package/dist/cjs/__tests__/db/pg/pg-insert.spec.js +294 -0
- package/dist/cjs/__tests__/db/pg/pg-insert.spec.js.map +1 -0
- package/dist/cjs/__tests__/db/pg/pg-prepare-sql-value.spec.js +575 -0
- package/dist/cjs/__tests__/db/pg/pg-prepare-sql-value.spec.js.map +1 -0
- package/dist/cjs/__tests__/db/pg/pg-table-schema.spec.js +117 -0
- package/dist/cjs/__tests__/db/pg/pg-table-schema.spec.js.map +1 -0
- package/dist/cjs/src/@types/i-data-types-ms.js +3 -0
- package/dist/cjs/src/@types/i-data-types-ms.js.map +1 -0
- package/dist/cjs/src/@types/i-data-types-pg.js +7 -0
- package/dist/cjs/src/@types/i-data-types-pg.js.map +1 -0
- package/dist/cjs/src/@types/i-pg.js +0 -21
- package/dist/cjs/src/@types/i-pg.js.map +1 -1
- package/dist/cjs/src/common.js +6 -5
- package/dist/cjs/src/common.js.map +1 -1
- package/dist/cjs/src/index.js +75 -54
- package/dist/cjs/src/index.js.map +1 -1
- package/dist/cjs/src/ms/gen-table-interfaces-ms.js +64 -0
- package/dist/cjs/src/ms/gen-table-interfaces-ms.js.map +1 -0
- package/dist/cjs/src/ms/get-sql/insert.js +37 -0
- package/dist/cjs/src/ms/get-sql/insert.js.map +1 -0
- package/dist/cjs/src/ms/get-sql/merge.js +93 -0
- package/dist/cjs/src/ms/get-sql/merge.js.map +1 -0
- package/dist/cjs/src/ms/get-sql/update.js +32 -0
- package/dist/cjs/src/ms/get-sql/update.js.map +1 -0
- package/dist/cjs/src/{mssql → ms}/pool-ms.js +6 -23
- package/dist/cjs/src/ms/pool-ms.js.map +1 -0
- package/dist/cjs/src/ms/prepare-value.js +178 -0
- package/dist/cjs/src/ms/prepare-value.js.map +1 -0
- package/dist/cjs/src/{mssql → ms}/query-ms.js +1 -1
- package/dist/cjs/src/ms/query-ms.js.map +1 -0
- package/dist/cjs/src/ms/table-schema-ms.js +241 -0
- package/dist/cjs/src/ms/table-schema-ms.js.map +1 -0
- package/dist/cjs/src/ms/utils-ms.js +92 -0
- package/dist/cjs/src/ms/utils-ms.js.map +1 -0
- package/dist/cjs/src/ms/wrap-transaction-ms.js +32 -0
- package/dist/cjs/src/ms/wrap-transaction-ms.js.map +1 -0
- package/dist/cjs/src/pg/gen-table-interfaces-pg.js +83 -0
- package/dist/cjs/src/pg/gen-table-interfaces-pg.js.map +1 -0
- package/dist/cjs/src/pg/get-sql/insert.js +38 -0
- package/dist/cjs/src/pg/get-sql/insert.js.map +1 -0
- package/dist/cjs/src/pg/get-sql/merge.js +60 -0
- package/dist/cjs/src/pg/get-sql/merge.js.map +1 -0
- package/dist/cjs/src/pg/get-sql/update.js +32 -0
- package/dist/cjs/src/pg/get-sql/update.js.map +1 -0
- package/dist/cjs/src/pg/{insert.js → insert-pg.js} +10 -10
- package/dist/cjs/src/pg/insert-pg.js.map +1 -0
- package/dist/cjs/src/pg/is-table-or-view-exists.js +1 -2
- package/dist/cjs/src/pg/is-table-or-view-exists.js.map +1 -1
- package/dist/cjs/src/pg/{pg-pool.js → pool-pg.js} +6 -7
- package/dist/cjs/src/pg/pool-pg.js.map +1 -0
- package/dist/cjs/src/pg/prepare-value.js +116 -69
- package/dist/cjs/src/pg/prepare-value.js.map +1 -1
- package/dist/cjs/src/pg/query-pg.js +2 -2
- package/dist/cjs/src/pg/query-pg.js.map +1 -1
- package/dist/cjs/src/pg/table-schema-pg.js +183 -0
- package/dist/cjs/src/pg/table-schema-pg.js.map +1 -0
- package/dist/cjs/src/pg/utils-pg.js +99 -0
- package/dist/cjs/src/pg/utils-pg.js.map +1 -0
- package/dist/cjs/src/utils/utils-array.js +152 -0
- package/dist/cjs/src/utils/utils-array.js.map +1 -0
- package/dist/cjs/src/utils/utils-dt.js +121 -0
- package/dist/cjs/src/utils/utils-dt.js.map +1 -0
- package/dist/cjs/src/utils/utils-num.js +127 -0
- package/dist/cjs/src/utils/utils-num.js.map +1 -0
- package/dist/cjs/src/utils/utils.js +66 -0
- package/dist/cjs/src/utils/utils.js.map +1 -0
- package/dist/esm/src/@types/i-data-types-ms.js +2 -0
- package/dist/esm/src/@types/i-data-types-ms.js.map +1 -0
- package/dist/esm/src/@types/i-data-types-pg.js +6 -0
- package/dist/esm/src/@types/i-data-types-pg.js.map +1 -0
- package/dist/esm/src/@types/i-pg.js +1 -20
- package/dist/esm/src/@types/i-pg.js.map +1 -1
- package/dist/esm/src/common.js +3 -2
- package/dist/esm/src/common.js.map +1 -1
- package/dist/esm/src/index.js +24 -15
- package/dist/esm/src/index.js.map +1 -1
- package/dist/esm/src/ms/gen-table-interfaces-ms.js +36 -0
- package/dist/esm/src/ms/gen-table-interfaces-ms.js.map +1 -0
- package/dist/esm/src/ms/get-sql/insert.js +33 -0
- package/dist/esm/src/ms/get-sql/insert.js.map +1 -0
- package/dist/esm/src/ms/get-sql/merge.js +89 -0
- package/dist/esm/src/ms/get-sql/merge.js.map +1 -0
- package/dist/esm/src/ms/get-sql/update.js +28 -0
- package/dist/esm/src/ms/get-sql/update.js.map +1 -0
- package/dist/esm/src/{mssql → ms}/pool-ms.js +5 -20
- package/dist/esm/src/ms/pool-ms.js.map +1 -0
- package/dist/esm/src/ms/prepare-value.js +149 -0
- package/dist/esm/src/ms/prepare-value.js.map +1 -0
- package/dist/esm/src/{mssql → ms}/query-ms.js +1 -1
- package/dist/esm/src/ms/query-ms.js.map +1 -0
- package/dist/esm/src/ms/table-schema-ms.js +213 -0
- package/dist/esm/src/ms/table-schema-ms.js.map +1 -0
- package/dist/esm/src/ms/utils-ms.js +65 -0
- package/dist/esm/src/ms/utils-ms.js.map +1 -0
- package/dist/esm/src/ms/wrap-transaction-ms.js +28 -0
- package/dist/esm/src/ms/wrap-transaction-ms.js.map +1 -0
- package/dist/esm/src/pg/gen-table-interfaces-pg.js +55 -0
- package/dist/esm/src/pg/gen-table-interfaces-pg.js.map +1 -0
- package/dist/esm/src/pg/get-sql/insert.js +34 -0
- package/dist/esm/src/pg/get-sql/insert.js.map +1 -0
- package/dist/esm/src/pg/get-sql/merge.js +56 -0
- package/dist/esm/src/pg/get-sql/merge.js.map +1 -0
- package/dist/esm/src/pg/get-sql/update.js +28 -0
- package/dist/esm/src/pg/get-sql/update.js.map +1 -0
- package/dist/esm/src/pg/{insert.js → insert-pg.js} +10 -10
- package/dist/esm/src/pg/insert-pg.js.map +1 -0
- package/dist/esm/src/pg/is-table-or-view-exists.js +1 -2
- package/dist/esm/src/pg/is-table-or-view-exists.js.map +1 -1
- package/dist/esm/src/pg/{pg-pool.js → pool-pg.js} +6 -7
- package/dist/esm/src/pg/pool-pg.js.map +1 -0
- package/dist/esm/src/pg/prepare-value.js +113 -67
- package/dist/esm/src/pg/prepare-value.js.map +1 -1
- package/dist/esm/src/pg/query-pg.js +1 -1
- package/dist/esm/src/pg/query-pg.js.map +1 -1
- package/dist/esm/src/pg/table-schema-pg.js +178 -0
- package/dist/esm/src/pg/table-schema-pg.js.map +1 -0
- package/dist/esm/src/pg/utils-pg.js +93 -0
- package/dist/esm/src/pg/utils-pg.js.map +1 -0
- package/dist/esm/src/utils/utils-array.js +125 -0
- package/dist/esm/src/utils/utils-array.js.map +1 -0
- package/dist/esm/src/utils/utils-dt.js +114 -0
- package/dist/esm/src/utils/utils-dt.js.map +1 -0
- package/dist/esm/src/utils/utils-num.js +117 -0
- package/dist/esm/src/utils/utils-num.js.map +1 -0
- package/dist/esm/src/utils/utils.js +58 -0
- package/dist/esm/src/utils/utils.js.map +1 -0
- package/dist/types/src/@types/i-common.d.ts +35 -3
- package/dist/types/src/@types/i-common.d.ts.map +1 -1
- package/dist/types/src/@types/i-data-types-ms.d.ts +3 -0
- package/dist/types/src/@types/i-data-types-ms.d.ts.map +1 -0
- package/dist/types/src/@types/i-data-types-pg.d.ts +35 -0
- package/dist/types/src/@types/i-data-types-pg.d.ts.map +1 -0
- package/dist/types/src/@types/i-ms.d.ts +26 -126
- package/dist/types/src/@types/i-ms.d.ts.map +1 -1
- package/dist/types/src/@types/i-pg.d.ts +11 -35
- package/dist/types/src/@types/i-pg.d.ts.map +1 -1
- package/dist/types/src/common.d.ts +1 -0
- package/dist/types/src/common.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +28 -16
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/ms/gen-table-interfaces-ms.d.ts +3 -0
- package/dist/types/src/ms/gen-table-interfaces-ms.d.ts.map +1 -0
- package/dist/types/src/ms/get-sql/insert.d.ts +9 -0
- package/dist/types/src/ms/get-sql/insert.d.ts.map +1 -0
- package/dist/types/src/ms/get-sql/merge.d.ts +14 -0
- package/dist/types/src/ms/get-sql/merge.d.ts.map +1 -0
- package/dist/types/src/ms/get-sql/update.d.ts +9 -0
- package/dist/types/src/ms/get-sql/update.d.ts.map +1 -0
- package/dist/types/src/{mssql → ms}/pool-ms.d.ts +0 -8
- package/dist/types/src/ms/pool-ms.d.ts.map +1 -0
- package/dist/types/src/ms/prepare-value.d.ts +12 -0
- package/dist/types/src/ms/prepare-value.d.ts.map +1 -0
- package/dist/types/src/ms/query-ms.d.ts +3 -0
- package/dist/types/src/ms/query-ms.d.ts.map +1 -0
- package/dist/types/src/ms/table-schema-ms.d.ts +9 -0
- package/dist/types/src/ms/table-schema-ms.d.ts.map +1 -0
- package/dist/types/src/ms/utils-ms.d.ts +3 -0
- package/dist/types/src/ms/utils-ms.d.ts.map +1 -0
- package/dist/types/src/ms/wrap-transaction-ms.d.ts +5 -0
- package/dist/types/src/ms/wrap-transaction-ms.d.ts.map +1 -0
- package/dist/types/src/pg/gen-table-interfaces-pg.d.ts +3 -0
- package/dist/types/src/pg/gen-table-interfaces-pg.d.ts.map +1 -0
- package/dist/types/src/pg/get-sql/insert.d.ts +9 -0
- package/dist/types/src/pg/get-sql/insert.d.ts.map +1 -0
- package/dist/types/src/pg/get-sql/merge.d.ts +10 -0
- package/dist/types/src/pg/get-sql/merge.d.ts.map +1 -0
- package/dist/types/src/pg/get-sql/update.d.ts +9 -0
- package/dist/types/src/pg/get-sql/update.d.ts.map +1 -0
- package/dist/types/src/pg/{insert.d.ts → insert-pg.d.ts} +3 -3
- package/dist/types/src/pg/insert-pg.d.ts.map +1 -0
- package/dist/types/src/pg/{pg-pool.d.ts → pool-pg.d.ts} +1 -1
- package/dist/types/src/pg/{pg-pool.d.ts.map → pool-pg.d.ts.map} +1 -1
- package/dist/types/src/pg/prepare-value.d.ts +3 -1
- package/dist/types/src/pg/prepare-value.d.ts.map +1 -1
- package/dist/types/src/pg/query-pg.d.ts +3 -2
- package/dist/types/src/pg/query-pg.d.ts.map +1 -1
- package/dist/types/src/pg/table-schema-pg.d.ts +12 -0
- package/dist/types/src/pg/table-schema-pg.d.ts.map +1 -0
- package/dist/types/src/pg/utils-pg.d.ts +5 -0
- package/dist/types/src/pg/utils-pg.d.ts.map +1 -0
- package/dist/types/src/utils/utils-array.d.ts +5 -0
- package/dist/types/src/utils/utils-array.d.ts.map +1 -0
- package/dist/types/src/utils/utils-dt.d.ts +15 -0
- package/dist/types/src/utils/utils-dt.d.ts.map +1 -0
- package/dist/types/src/utils/utils-num.d.ts +9 -0
- package/dist/types/src/utils/utils-num.d.ts.map +1 -0
- package/dist/types/src/utils/utils.d.ts +18 -0
- package/dist/types/src/utils/utils.d.ts.map +1 -0
- package/package.json +13 -13
- package/src/@types/i-common.ts +42 -4
- package/src/@types/i-data-types-ms.ts +81 -0
- package/src/@types/i-data-types-pg.ts +120 -0
- package/src/@types/i-ms.ts +29 -153
- package/src/@types/i-pg.ts +11 -36
- package/src/common.ts +4 -2
- package/src/index.ts +101 -59
- package/src/ms/gen-table-interfaces-ms.ts +52 -0
- package/src/ms/get-sql/insert.ts +45 -0
- package/src/ms/get-sql/merge.ts +118 -0
- package/src/ms/get-sql/update.ts +46 -0
- package/src/{mssql → ms}/pool-ms.ts +0 -16
- package/src/ms/prepare-value.ts +175 -0
- package/src/{mssql → ms}/query-ms.ts +2 -2
- package/src/ms/table-schema-ms.ts +231 -0
- package/src/ms/utils-ms.ts +72 -0
- package/src/ms/wrap-transaction-ms.ts +27 -0
- package/src/pg/gen-table-interfaces-pg.ts +74 -0
- package/src/pg/get-sql/insert.ts +46 -0
- package/src/pg/get-sql/merge.ts +70 -0
- package/src/pg/get-sql/update.ts +46 -0
- package/src/pg/{insert.ts → insert-pg.ts} +9 -9
- package/src/pg/prepare-value.ts +129 -67
- package/src/pg/query-pg.ts +4 -3
- package/src/pg/table-schema-pg.ts +196 -0
- package/src/pg/utils-pg.ts +97 -0
- package/src/utils/utils-array.ts +133 -0
- package/src/utils/utils-dt.ts +123 -0
- package/src/utils/utils-num.ts +131 -0
- package/src/utils/utils.ts +64 -0
- package/dist/cjs/__tests__/02_getValueForSqlMs.spec.js +0 -50
- package/dist/cjs/__tests__/02_getValueForSqlMs.spec.js.map +0 -1
- package/dist/cjs/src/mssql/get-value-for-sql.js +0 -277
- package/dist/cjs/src/mssql/get-value-for-sql.js.map +0 -1
- package/dist/cjs/src/mssql/pool-ms.js.map +0 -1
- package/dist/cjs/src/mssql/query-ms.js.map +0 -1
- package/dist/cjs/src/mssql/sql.js +0 -427
- package/dist/cjs/src/mssql/sql.js.map +0 -1
- package/dist/cjs/src/mssql/utils.js +0 -36
- package/dist/cjs/src/mssql/utils.js.map +0 -1
- package/dist/cjs/src/pg/get-merge-sql.js +0 -52
- package/dist/cjs/src/pg/get-merge-sql.js.map +0 -1
- package/dist/cjs/src/pg/get-update-sql.js +0 -30
- package/dist/cjs/src/pg/get-update-sql.js.map +0 -1
- package/dist/cjs/src/pg/insert.js.map +0 -1
- package/dist/cjs/src/pg/pg-pool.js.map +0 -1
- package/dist/cjs/src/pg/table-schema.js +0 -179
- package/dist/cjs/src/pg/table-schema.js.map +0 -1
- package/dist/cjs/src/utils.js +0 -17
- package/dist/cjs/src/utils.js.map +0 -1
- package/dist/esm/src/mssql/get-value-for-sql.js +0 -272
- package/dist/esm/src/mssql/get-value-for-sql.js.map +0 -1
- package/dist/esm/src/mssql/pool-ms.js.map +0 -1
- package/dist/esm/src/mssql/query-ms.js.map +0 -1
- package/dist/esm/src/mssql/sql.js +0 -390
- package/dist/esm/src/mssql/sql.js.map +0 -1
- package/dist/esm/src/mssql/utils.js +0 -31
- package/dist/esm/src/mssql/utils.js.map +0 -1
- package/dist/esm/src/pg/get-merge-sql.js +0 -48
- package/dist/esm/src/pg/get-merge-sql.js.map +0 -1
- package/dist/esm/src/pg/get-update-sql.js +0 -26
- package/dist/esm/src/pg/get-update-sql.js.map +0 -1
- package/dist/esm/src/pg/insert.js.map +0 -1
- package/dist/esm/src/pg/pg-pool.js.map +0 -1
- package/dist/esm/src/pg/table-schema.js +0 -174
- package/dist/esm/src/pg/table-schema.js.map +0 -1
- package/dist/esm/src/utils.js +0 -14
- package/dist/esm/src/utils.js.map +0 -1
- package/dist/types/src/mssql/get-value-for-sql.d.ts +0 -11
- package/dist/types/src/mssql/get-value-for-sql.d.ts.map +0 -1
- package/dist/types/src/mssql/pool-ms.d.ts.map +0 -1
- package/dist/types/src/mssql/query-ms.d.ts +0 -3
- package/dist/types/src/mssql/query-ms.d.ts.map +0 -1
- package/dist/types/src/mssql/sql.d.ts +0 -57
- package/dist/types/src/mssql/sql.d.ts.map +0 -1
- package/dist/types/src/mssql/utils.d.ts +0 -10
- package/dist/types/src/mssql/utils.d.ts.map +0 -1
- package/dist/types/src/pg/get-merge-sql.d.ts +0 -9
- package/dist/types/src/pg/get-merge-sql.d.ts.map +0 -1
- package/dist/types/src/pg/get-update-sql.d.ts +0 -3
- package/dist/types/src/pg/get-update-sql.d.ts.map +0 -1
- package/dist/types/src/pg/insert.d.ts.map +0 -1
- package/dist/types/src/pg/table-schema.d.ts +0 -12
- package/dist/types/src/pg/table-schema.d.ts.map +0 -1
- package/dist/types/src/utils.d.ts +0 -9
- package/dist/types/src/utils.d.ts.map +0 -1
- package/src/mssql/get-value-for-sql.ts +0 -325
- package/src/mssql/sql.ts +0 -430
- package/src/mssql/utils.ts +0 -31
- package/src/pg/get-merge-sql.ts +0 -62
- package/src/pg/get-update-sql.ts +0 -32
- package/src/pg/table-schema.ts +0 -189
- package/src/utils.ts +0 -14
- /package/src/pg/{pg-pool.ts → pool-pg.ts} +0 -0
|
@@ -1,85 +1,132 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.prepareSqlValuePg = exports.prepareSqlStringPg = void 0;
|
|
4
|
-
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const
|
|
9
|
-
const
|
|
10
|
-
|
|
11
|
-
if (
|
|
12
|
-
return
|
|
3
|
+
exports.prepareSqlValuePg = exports.prepareSqlStringPg = exports.quoteStringPg = void 0;
|
|
4
|
+
const af_tools_ts_1 = require("af-tools-ts");
|
|
5
|
+
const common_1 = require("../common");
|
|
6
|
+
const utils_dt_1 = require("../utils/utils-dt");
|
|
7
|
+
const utils_num_1 = require("../utils/utils-num");
|
|
8
|
+
const utils_1 = require("../utils/utils");
|
|
9
|
+
const utils_array_1 = require("../utils/utils-array");
|
|
10
|
+
const quoteStringPg = (value) => {
|
|
11
|
+
if (value == null) {
|
|
12
|
+
return common_1.NULL;
|
|
13
13
|
}
|
|
14
|
-
return `'${
|
|
14
|
+
return /['\\]|\${2,}/.test(value) ? `$s$${value}$s$` : `'${value}'`;
|
|
15
|
+
};
|
|
16
|
+
exports.quoteStringPg = quoteStringPg;
|
|
17
|
+
const prepareSqlStringPg = (value, fieldDef) => {
|
|
18
|
+
if (value == null) {
|
|
19
|
+
return common_1.NULL;
|
|
20
|
+
}
|
|
21
|
+
let v = String(value);
|
|
22
|
+
const { length = 0, noQuotes } = fieldDef;
|
|
23
|
+
if (length > 0 && v.length > length) {
|
|
24
|
+
v = v.substring(0, length);
|
|
25
|
+
}
|
|
26
|
+
if (noQuotes) {
|
|
27
|
+
return v;
|
|
28
|
+
}
|
|
29
|
+
return (0, exports.quoteStringPg)(v);
|
|
15
30
|
};
|
|
16
31
|
exports.prepareSqlStringPg = prepareSqlStringPg;
|
|
32
|
+
const prepareDateTimeOffset = (value, fieldDef) => (0, utils_dt_1.getDatetimeWithPrecisionAndOffset)({ value, fieldDef, defaultDtPrecision: 6 });
|
|
33
|
+
const prepareTimeOffset = (value, fieldDefOriginal) => {
|
|
34
|
+
const fieldDef = { ...fieldDefOriginal, noQuotes: true };
|
|
35
|
+
fieldDef.dateTimeOptions = fieldDef.dateTimeOptions || {};
|
|
36
|
+
const { includeOffset = fieldDef.dataType === 'timetz' } = fieldDef.dateTimeOptions;
|
|
37
|
+
fieldDef.dateTimeOptions.includeOffset = includeOffset;
|
|
38
|
+
const dts = (0, utils_dt_1.getDatetimeWithPrecisionAndOffset)({ value, fieldDef, defaultDtPrecision: 6, stripTrailingZeros: true });
|
|
39
|
+
return dts === common_1.NULL ? common_1.NULL : `'${dts.substring(11, dts.length)}'::${fieldDef.dataType}`;
|
|
40
|
+
};
|
|
41
|
+
const prepareJsonPg = (value, dataType) => {
|
|
42
|
+
const v = (0, utils_1.prepareJSON)(value);
|
|
43
|
+
if (v === common_1.NULL) {
|
|
44
|
+
return common_1.NULL;
|
|
45
|
+
}
|
|
46
|
+
return `${(0, exports.quoteStringPg)(v)}::${dataType}`;
|
|
47
|
+
};
|
|
17
48
|
const prepareSqlValuePg = (arg) => {
|
|
18
49
|
const { value, fieldDef } = arg;
|
|
19
|
-
if (value == null
|
|
20
|
-
return NULL;
|
|
50
|
+
if (value == null) {
|
|
51
|
+
return common_1.NULL;
|
|
21
52
|
}
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
case
|
|
27
|
-
return
|
|
53
|
+
const fieldDefWithNoQuotes = { ...fieldDef, noQuotes: true };
|
|
54
|
+
let v = value;
|
|
55
|
+
const { noQuotes, dataType } = fieldDef;
|
|
56
|
+
switch (dataType) {
|
|
57
|
+
case 'bit':
|
|
58
|
+
return (0, af_tools_ts_1.getBool)(value) ? '1' : '0';
|
|
59
|
+
case 'bool':
|
|
60
|
+
case 'boolean':
|
|
61
|
+
return (0, af_tools_ts_1.getBool)(value) ? 'true' : 'false';
|
|
62
|
+
case 'smallint':
|
|
63
|
+
case 'int2':
|
|
64
|
+
return (0, utils_num_1.prepareIntNumber)(value, -32768, 32767);
|
|
65
|
+
case 'int':
|
|
66
|
+
case 'integer':
|
|
67
|
+
case 'int4':
|
|
68
|
+
return (0, utils_num_1.prepareIntNumber)(value, -2147483648, 2147483647);
|
|
69
|
+
case 'bigint':
|
|
70
|
+
case 'int8':
|
|
71
|
+
return (0, utils_num_1.prepareBigIntNumber)(value);
|
|
72
|
+
case 'numeric':
|
|
73
|
+
case 'decimal':
|
|
74
|
+
return (0, utils_num_1.prepareNumeric)(value, fieldDef.precision, fieldDef.scale);
|
|
75
|
+
case 'real':
|
|
76
|
+
case 'float4':
|
|
77
|
+
case 'money':
|
|
78
|
+
case 'double precision':
|
|
79
|
+
case 'float8':
|
|
80
|
+
return (0, utils_num_1.prepareFloatNumber)(value);
|
|
81
|
+
case 'json':
|
|
82
|
+
case 'jsonb':
|
|
83
|
+
return prepareJsonPg(value, dataType);
|
|
84
|
+
case 'uuid':
|
|
85
|
+
return (0, utils_1.prepareUUID)(v, true, fieldDef.noQuotes);
|
|
86
|
+
case 'string':
|
|
87
|
+
case 'text':
|
|
88
|
+
case 'character':
|
|
89
|
+
case 'char':
|
|
90
|
+
case 'varchar':
|
|
91
|
+
case 'character varying':
|
|
92
|
+
return (0, exports.prepareSqlStringPg)(value, fieldDef);
|
|
93
|
+
case 'timestamp':
|
|
94
|
+
case 'timestamp without time zone': {
|
|
95
|
+
// '2023-09-05T02:23:54.105+03:00'::timestamp
|
|
96
|
+
// '2023-09-05T02:23:54.105'::timestamp
|
|
97
|
+
const { includeOffset = false } = fieldDef.dateTimeOptions || {}; // По умолчанию для timestamp includeOffset = false
|
|
98
|
+
const str = prepareDateTimeOffset(value, { ...fieldDef, noQuotes: true, dateTimeOptions: { ...(fieldDef.dateTimeOptions || {}), includeOffset } });
|
|
99
|
+
return str === common_1.NULL ? common_1.NULL : `'${str}'::timestamp`;
|
|
28
100
|
}
|
|
29
|
-
case
|
|
30
|
-
case
|
|
31
|
-
|
|
32
|
-
|
|
101
|
+
case 'timestamptz':
|
|
102
|
+
case 'timestamp with time zone': {
|
|
103
|
+
// '2023-09-05T02:23:54.105'::timestamptz
|
|
104
|
+
// '2023-09-05T02:23:54.105+03:00'::timestamptz
|
|
105
|
+
const str = prepareDateTimeOffset(value, fieldDefWithNoQuotes);
|
|
106
|
+
return str === common_1.NULL ? common_1.NULL : `'${str}'::timestamptz`;
|
|
33
107
|
}
|
|
34
|
-
case
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
case
|
|
40
|
-
case
|
|
41
|
-
|
|
42
|
-
case
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
case
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
case i_pg_1.EDataTypePg.date:
|
|
50
|
-
case i_pg_1.EDataTypePg.timestamp:
|
|
51
|
-
case i_pg_1.EDataTypePg.timestamptz: {
|
|
52
|
-
let v = value;
|
|
53
|
-
if (value instanceof Date) {
|
|
54
|
-
v = +value;
|
|
55
|
-
}
|
|
56
|
-
else if (value instanceof luxon_1.DateTime) {
|
|
57
|
-
v = value.toMillis();
|
|
108
|
+
case 'date':
|
|
109
|
+
// '2023-09-05'::date
|
|
110
|
+
return (0, utils_dt_1.dateTimeValue)(value, fieldDefWithNoQuotes, (dt) => `'${dt.toISODate()}'::date`);
|
|
111
|
+
case 'timetz': // '02:22:17.368+03:00'::time
|
|
112
|
+
case 'time with time zone':
|
|
113
|
+
case 'time': // '02:22:17.368'::time
|
|
114
|
+
case 'time without time zone':
|
|
115
|
+
return prepareTimeOffset(value, fieldDef);
|
|
116
|
+
case 'bytea':
|
|
117
|
+
v = (0, utils_1.binToHexString)(value);
|
|
118
|
+
return v ? (0, utils_1.q)(v, noQuotes) : common_1.NULL;
|
|
119
|
+
case 'ARRAY': {
|
|
120
|
+
v = (0, utils_array_1.arrayToJsonList)(value, fieldDef.arrayType);
|
|
121
|
+
if (v === common_1.NULL) {
|
|
122
|
+
return common_1.NULL;
|
|
58
123
|
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
}
|
|
62
|
-
switch (fieldDef.dataType) {
|
|
63
|
-
case i_pg_1.EDataTypePg.date: {
|
|
64
|
-
return `'${typeof v === 'number' ? utc$(v).toISODate() : v}'::date`;
|
|
65
|
-
}
|
|
66
|
-
case i_pg_1.EDataTypePg.timestamp:
|
|
67
|
-
case i_pg_1.EDataTypePg.timestamptz: {
|
|
68
|
-
return `'${typeof v === 'number' ? utc$(v).toISO() : v}'::timestamptz`;
|
|
69
|
-
}
|
|
70
|
-
default:
|
|
71
|
-
return `'${v}'`;
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
case i_pg_1.EDataTypePg.USER_DEFINED:
|
|
75
|
-
return (0, exports.prepareSqlStringPg)(value);
|
|
76
|
-
case i_pg_1.EDataTypePg.ARRAY: {
|
|
77
|
-
let v = JSON.stringify(value);
|
|
78
|
-
v = v.replace(/^\[(.*?)]$/, '{$1}');
|
|
79
|
-
return (0, exports.prepareSqlStringPg)(v);
|
|
124
|
+
v = `{${v}}`;
|
|
125
|
+
return fieldDef.noQuotes ? v : (0, exports.quoteStringPg)(v);
|
|
80
126
|
}
|
|
127
|
+
// 'USER_DEFINED'
|
|
81
128
|
default:
|
|
82
|
-
return (0, exports.prepareSqlStringPg)(value);
|
|
129
|
+
return (0, exports.prepareSqlStringPg)(value, fieldDef);
|
|
83
130
|
}
|
|
84
131
|
};
|
|
85
132
|
exports.prepareSqlValuePg = prepareSqlValuePg;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepare-value.js","sourceRoot":"","sources":["../../../../src/pg/prepare-value.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"prepare-value.js","sourceRoot":"","sources":["../../../../src/pg/prepare-value.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.queryPg = void 0;
|
|
4
|
-
const
|
|
4
|
+
const pool_pg_1 = require("./pool-pg");
|
|
5
5
|
const common_1 = require("../common");
|
|
6
6
|
const queryPg = async (connectionId, sqlText, sqlValues, throwError, prefix) => {
|
|
7
|
-
const pool = await (0,
|
|
7
|
+
const pool = await (0, pool_pg_1.getPoolPg)(connectionId);
|
|
8
8
|
let res;
|
|
9
9
|
try {
|
|
10
10
|
if (Array.isArray(sqlValues)) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"query-pg.js","sourceRoot":"","sources":["../../../../src/pg/query-pg.ts"],"names":[],"mappings":";;;AACA,uCAAsC;AACtC,sCAAwC;
|
|
1
|
+
{"version":3,"file":"query-pg.js","sourceRoot":"","sources":["../../../../src/pg/query-pg.ts"],"names":[],"mappings":";;;AACA,uCAAsC;AACtC,sCAAwC;AAIjC,MAAM,OAAO,GAAG,KAAK,EAC1B,YAAoB,EACpB,OAAe,EACf,SAAiB,EACjB,UAAoB,EACpB,MAAe,EAEqB,EAAE;IACtC,MAAM,IAAI,GAAY,MAAM,IAAA,mBAAS,EAAC,YAAY,CAAC,CAAC;IACpD,IAAI,GAAgB,CAAC;IACrB,IAAI,CAAC;QACH,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;YAC7B,GAAG,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC7C,CAAC;aAAM,CAAC;YACN,GAAG,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAClC,CAAC;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,IAAA,oBAAW,EAAC,GAAG,EAAE,CAAC,UAAU,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;IACjD,CAAC;AACH,CAAC,CAAC;AApBW,QAAA,OAAO,WAoBlB"}
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getFieldsAndValuesPg = exports.getTableSchemaPg = void 0;
|
|
4
|
+
// noinspection SqlResolve
|
|
5
|
+
const query_pg_1 = require("./query-pg");
|
|
6
|
+
const logger_error_1 = require("../logger-error");
|
|
7
|
+
const common_1 = require("../common");
|
|
8
|
+
const utils_1 = require("../utils/utils");
|
|
9
|
+
const utils_pg_1 = require("./utils-pg");
|
|
10
|
+
// commonSchemaAndTable: <schema>.<table> : Staff.nnPersones-personGuid
|
|
11
|
+
// schemaAndTablePg: "<schema>"."<table>" : "Staff"."nnPersones-personGuid"
|
|
12
|
+
const tableSchemaHash = {};
|
|
13
|
+
const getColumnsSchemaPg_ = async (connectionId, commonSchemaAndTable) => {
|
|
14
|
+
const [schema, table] = utils_1.schemaTable.to.common(commonSchemaAndTable).split('.');
|
|
15
|
+
const sql = `SELECT column_name,
|
|
16
|
+
column_default,
|
|
17
|
+
is_nullable,
|
|
18
|
+
data_type,
|
|
19
|
+
character_maximum_length,
|
|
20
|
+
numeric_precision,
|
|
21
|
+
numeric_precision_radix,
|
|
22
|
+
numeric_scale,
|
|
23
|
+
datetime_precision,
|
|
24
|
+
udt_name,
|
|
25
|
+
is_generated
|
|
26
|
+
FROM information_schema.columns
|
|
27
|
+
WHERE table_name = '${table}'
|
|
28
|
+
AND table_schema = '${schema}';`;
|
|
29
|
+
const result = await (0, query_pg_1.queryPg)(connectionId, sql);
|
|
30
|
+
const fields = result?.rows || [];
|
|
31
|
+
const columnsSchema = {};
|
|
32
|
+
fields.forEach((fieldDef) => {
|
|
33
|
+
const columnDefault = fieldDef.column_default != null ? fieldDef.column_default : undefined;
|
|
34
|
+
const name = fieldDef.column_name;
|
|
35
|
+
const dataType = (0, utils_pg_1.getNormalizedTypePg)(fieldDef.data_type);
|
|
36
|
+
const fieldSchema = {
|
|
37
|
+
name,
|
|
38
|
+
isNullable: /yes/i.test(fieldDef.is_nullable || ''),
|
|
39
|
+
columnDefault: fieldDef.column_default,
|
|
40
|
+
hasDefault: columnDefault != null,
|
|
41
|
+
dataType,
|
|
42
|
+
length: fieldDef.character_maximum_length,
|
|
43
|
+
precision: fieldDef.numeric_precision,
|
|
44
|
+
scale: fieldDef.numeric_scale,
|
|
45
|
+
radix: fieldDef.numeric_precision_radix,
|
|
46
|
+
dtPrecision: fieldDef.datetime_precision,
|
|
47
|
+
arrayType: dataType === 'ARRAY' ? (0, utils_pg_1.getTypeByUdtNamePg)(fieldDef.udt_name) : undefined,
|
|
48
|
+
readOnly: fieldDef.is_generated === 'ALWAYS', // boolean;
|
|
49
|
+
};
|
|
50
|
+
Object.entries(fieldSchema).forEach(([prop, value]) => {
|
|
51
|
+
if (value == null) {
|
|
52
|
+
delete fieldSchema[prop];
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
columnsSchema[name] = fieldSchema;
|
|
56
|
+
});
|
|
57
|
+
return columnsSchema;
|
|
58
|
+
};
|
|
59
|
+
const getPrimaryKey = async (connectionId, commonSchemaAndTable) => {
|
|
60
|
+
const schemaTablePg = utils_1.schemaTable.to.pg(commonSchemaAndTable);
|
|
61
|
+
const sql = `
|
|
62
|
+
SELECT a.attname as f
|
|
63
|
+
FROM pg_index i
|
|
64
|
+
JOIN pg_attribute a
|
|
65
|
+
ON a.attrelid = i.indrelid AND a.attnum = ANY (i.indkey)
|
|
66
|
+
WHERE i.indrelid = '${schemaTablePg}'::regclass
|
|
67
|
+
AND i.indisprimary;`;
|
|
68
|
+
const result = await (0, query_pg_1.queryPg)(connectionId, sql);
|
|
69
|
+
return (result?.rows || []).map(({ f }) => f);
|
|
70
|
+
};
|
|
71
|
+
const getUniqueConstraints = async (connectionId, commonSchemaAndTable) => {
|
|
72
|
+
const schemaTablePg = utils_1.schemaTable.to.pg(commonSchemaAndTable);
|
|
73
|
+
const [schema, table] = utils_1.schemaTable.to.common(commonSchemaAndTable).split('.');
|
|
74
|
+
const sql = `
|
|
75
|
+
SELECT UI.cn as cn, UI.cols as cols, CASE WHEN UC.cn IS NULL THEN 'UX' ELSE 'UC' END AS typ
|
|
76
|
+
FROM (SELECT c.relname as cn, array_to_json(array_agg(a.attname ORDER BY a.attname)) AS cols
|
|
77
|
+
FROM pg_index i
|
|
78
|
+
JOIN pg_attribute a ON a.attrelid = i.indrelid AND a.attnum = ANY (i.indkey)
|
|
79
|
+
JOIN pg_class AS c ON c.oid = i.indexrelid
|
|
80
|
+
WHERE i.indrelid = '${schemaTablePg}'::regclass
|
|
81
|
+
AND i.indisunique
|
|
82
|
+
AND NOT i.indisprimary
|
|
83
|
+
GROUP BY c.relname) AS UI
|
|
84
|
+
LEFT OUTER JOIN (SELECT ccu.constraint_name AS cn
|
|
85
|
+
FROM information_schema.table_constraints tc
|
|
86
|
+
JOIN information_schema.constraint_column_usage AS ccu USING (constraint_schema, constraint_name)
|
|
87
|
+
JOIN information_schema.columns AS c ON c.table_schema = tc.constraint_schema
|
|
88
|
+
AND tc.table_name = c.table_name AND ccu.column_name = c.column_name
|
|
89
|
+
WHERE tc.table_schema = '${schema}'
|
|
90
|
+
AND tc.table_name = '${table}'
|
|
91
|
+
AND tc.constraint_type = 'UNIQUE'
|
|
92
|
+
GROUP BY ccu.constraint_name) AS UC ON UC.cn = UI.cn
|
|
93
|
+
ORDER BY CASE WHEN UC.cn IS NULL THEN 2 ELSE 1 END
|
|
94
|
+
`;
|
|
95
|
+
const result = await (0, query_pg_1.queryPg)(connectionId, sql);
|
|
96
|
+
const uc = {};
|
|
97
|
+
result?.rows?.forEach(({ cn, cols }) => {
|
|
98
|
+
uc[cn] = cols;
|
|
99
|
+
});
|
|
100
|
+
return uc;
|
|
101
|
+
};
|
|
102
|
+
const getSerials = async (connectionId, commonSchemaAndTable) => {
|
|
103
|
+
const fqName = utils_1.schemaTable.to.common(commonSchemaAndTable);
|
|
104
|
+
const sql = `
|
|
105
|
+
WITH fq_objects AS (SELECT c.oid,
|
|
106
|
+
n.nspname || '.' || c.relname AS fqname,
|
|
107
|
+
c.relkind,
|
|
108
|
+
c.relname AS relation
|
|
109
|
+
FROM pg_class c
|
|
110
|
+
JOIN pg_namespace n ON n.oid = c.relnamespace),
|
|
111
|
+
sequences AS (SELECT oid, fqname FROM fq_objects WHERE relkind = 'S'),
|
|
112
|
+
tables AS (SELECT oid, fqname FROM fq_objects WHERE relkind = 'r')
|
|
113
|
+
SELECT t.fqname AS tbl, array_to_json(array_agg(a.attname ORDER BY a.attname)) AS cols
|
|
114
|
+
FROM pg_depend d
|
|
115
|
+
JOIN sequences s ON s.oid = d.objid
|
|
116
|
+
JOIN tables t ON t.oid = d.refobjid
|
|
117
|
+
JOIN pg_attribute a ON a.attrelid = d.refobjid and a.attnum = d.refobjsubid
|
|
118
|
+
WHERE d.deptype = 'a'
|
|
119
|
+
AND t.fqname = '${fqName}'
|
|
120
|
+
GROUP BY t.fqname
|
|
121
|
+
`;
|
|
122
|
+
const result = await (0, query_pg_1.queryPg)(connectionId, sql);
|
|
123
|
+
return result?.rows?.[0]?.cols || [];
|
|
124
|
+
};
|
|
125
|
+
const getTableSchemaPg = async (connectionId, commonSchemaAndTable) => {
|
|
126
|
+
let tableSchema = tableSchemaHash[commonSchemaAndTable];
|
|
127
|
+
if (tableSchema) {
|
|
128
|
+
return tableSchema;
|
|
129
|
+
}
|
|
130
|
+
try {
|
|
131
|
+
const columnsSchema = await getColumnsSchemaPg_(connectionId, commonSchemaAndTable);
|
|
132
|
+
const pk = await getPrimaryKey(connectionId, commonSchemaAndTable);
|
|
133
|
+
const uc = await getUniqueConstraints(connectionId, commonSchemaAndTable);
|
|
134
|
+
const serialsFields = await getSerials(connectionId, commonSchemaAndTable);
|
|
135
|
+
const defaults = {};
|
|
136
|
+
Object.values(columnsSchema).forEach((fieldDef) => {
|
|
137
|
+
const { name: f = '', columnDefault, hasDefault } = fieldDef;
|
|
138
|
+
if (hasDefault && !serialsFields.includes(f)) {
|
|
139
|
+
defaults[f] = `${columnDefault}`;
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
const fieldsArray = Object.keys(columnsSchema);
|
|
143
|
+
const readOnlyFields = Object.values(columnsSchema).filter((s) => s.readOnly).map((s) => s.name);
|
|
144
|
+
const fieldsWoSerialsAndRO = fieldsArray.filter((f) => !serialsFields.includes(f) && !readOnlyFields.includes(f));
|
|
145
|
+
tableSchema = {
|
|
146
|
+
columnsSchema, pk, uc, defaults, serialsFields, fieldsArray, fieldsWoSerialsAndRO, readOnlyFields,
|
|
147
|
+
};
|
|
148
|
+
tableSchemaHash[commonSchemaAndTable] = tableSchema;
|
|
149
|
+
}
|
|
150
|
+
catch (err) {
|
|
151
|
+
logger_error_1.logger.error(`Failed to get schema for table ${commonSchemaAndTable}`);
|
|
152
|
+
logger_error_1.logger.error(err);
|
|
153
|
+
await (0, common_1.graceExit)();
|
|
154
|
+
}
|
|
155
|
+
return tableSchema;
|
|
156
|
+
};
|
|
157
|
+
exports.getTableSchemaPg = getTableSchemaPg;
|
|
158
|
+
const getFieldsAndValuesPg = (record, columnsSchema) => {
|
|
159
|
+
const recordNormalized = {};
|
|
160
|
+
Object.entries(record).forEach(([f, v]) => {
|
|
161
|
+
const { dataType } = columnsSchema[f] || {};
|
|
162
|
+
if (!dataType) {
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
if ((dataType === 'jsonb' || dataType === 'json') && Array.isArray(v)) {
|
|
166
|
+
recordNormalized[f] = JSON.stringify(v);
|
|
167
|
+
}
|
|
168
|
+
else {
|
|
169
|
+
recordNormalized[f] = v;
|
|
170
|
+
}
|
|
171
|
+
});
|
|
172
|
+
const fields = Object.keys(recordNormalized);
|
|
173
|
+
const fieldsList = fields.join(', ');
|
|
174
|
+
const values = Object.values(recordNormalized);
|
|
175
|
+
const positionsList = fields.map((__, i) => `$${++i}`).join(', ');
|
|
176
|
+
const setFields = fields.map((f, i) => `${f} = $${++i}`).join(', ');
|
|
177
|
+
const upsertFields = fields.map((f) => `${f} = EXCLUDED.${f}`).join(',\n');
|
|
178
|
+
return {
|
|
179
|
+
fields, fieldsList, values, positionsList, setFields, upsertFields,
|
|
180
|
+
};
|
|
181
|
+
};
|
|
182
|
+
exports.getFieldsAndValuesPg = getFieldsAndValuesPg;
|
|
183
|
+
//# sourceMappingURL=table-schema-pg.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"table-schema-pg.js","sourceRoot":"","sources":["../../../../src/pg/table-schema-pg.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getNormalizedTypePg = exports.getTypeByUdtNamePg = exports.getJsTypeByTypePg = void 0;
|
|
4
|
+
const getJsTypeByTypePg = (dataType, arrayType) => {
|
|
5
|
+
switch (dataType) {
|
|
6
|
+
case 'boolean':
|
|
7
|
+
return 'boolean';
|
|
8
|
+
case 'bigint':
|
|
9
|
+
return 'string | number';
|
|
10
|
+
case 'integer':
|
|
11
|
+
case 'numeric':
|
|
12
|
+
case 'real':
|
|
13
|
+
case 'smallint':
|
|
14
|
+
return 'number';
|
|
15
|
+
case 'text':
|
|
16
|
+
case 'character':
|
|
17
|
+
case 'varchar':
|
|
18
|
+
case 'uuid':
|
|
19
|
+
return 'string';
|
|
20
|
+
case 'json':
|
|
21
|
+
case 'jsonb':
|
|
22
|
+
return 'any';
|
|
23
|
+
case 'date':
|
|
24
|
+
case 'timestamptz':
|
|
25
|
+
case 'timestamp':
|
|
26
|
+
return 'string | Date | number';
|
|
27
|
+
case 'USER_DEFINED':
|
|
28
|
+
return 'string';
|
|
29
|
+
case 'ARRAY': {
|
|
30
|
+
const jsType = (0, exports.getJsTypeByTypePg)(arrayType);
|
|
31
|
+
return `${jsType}[]`;
|
|
32
|
+
}
|
|
33
|
+
default:
|
|
34
|
+
return 'string';
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
exports.getJsTypeByTypePg = getJsTypeByTypePg;
|
|
38
|
+
const udtNames2TypeMap = {
|
|
39
|
+
_bit: 'bit',
|
|
40
|
+
_bool: 'bool',
|
|
41
|
+
_box: 'box',
|
|
42
|
+
_bytea: 'bytea',
|
|
43
|
+
_char: 'char',
|
|
44
|
+
_circle: 'circle',
|
|
45
|
+
_date: 'date',
|
|
46
|
+
_float4: 'real',
|
|
47
|
+
_float8: 'double precision',
|
|
48
|
+
_inet: 'inet',
|
|
49
|
+
_int2: 'smallint',
|
|
50
|
+
_int4: 'int',
|
|
51
|
+
_int8: 'bigint',
|
|
52
|
+
_interval: 'interval',
|
|
53
|
+
_lseg: 'lseg',
|
|
54
|
+
_macaddr: 'macaddr',
|
|
55
|
+
_money: 'money',
|
|
56
|
+
_numeric: 'numeric',
|
|
57
|
+
_path: 'path',
|
|
58
|
+
_point: 'point',
|
|
59
|
+
_polygon: 'polygon',
|
|
60
|
+
_text: 'text',
|
|
61
|
+
_time: 'time',
|
|
62
|
+
_timestamp: 'timestamp',
|
|
63
|
+
_timestamptz: 'timestamptz',
|
|
64
|
+
_timetz: 'timetz',
|
|
65
|
+
_uuid: 'uuid',
|
|
66
|
+
_varchar: 'varchar',
|
|
67
|
+
_xml: 'xml',
|
|
68
|
+
// _oid: 'oid',
|
|
69
|
+
// _abstime: 'abstime',
|
|
70
|
+
// _name: 'name',
|
|
71
|
+
};
|
|
72
|
+
const getTypeByUdtNamePg = (udtName) => {
|
|
73
|
+
const dataType = udtNames2TypeMap[udtName];
|
|
74
|
+
return dataType || 'varchar';
|
|
75
|
+
};
|
|
76
|
+
exports.getTypeByUdtNamePg = getTypeByUdtNamePg;
|
|
77
|
+
const typeNormalizationMap = {
|
|
78
|
+
bool: 'boolean',
|
|
79
|
+
int2: 'smallint',
|
|
80
|
+
integer: 'int',
|
|
81
|
+
int4: 'int',
|
|
82
|
+
int8: 'bigint',
|
|
83
|
+
serial2: 'smallserial',
|
|
84
|
+
serial4: 'serial',
|
|
85
|
+
serial8: 'bigserial',
|
|
86
|
+
decimal: 'numeric',
|
|
87
|
+
float4: 'real',
|
|
88
|
+
float8: 'double precision',
|
|
89
|
+
character: 'char',
|
|
90
|
+
'character varying': 'varchar',
|
|
91
|
+
'timestamp with time zone': 'timestamptz',
|
|
92
|
+
'timestamp without time zone': 'timestamp',
|
|
93
|
+
'time without time zone': 'time',
|
|
94
|
+
'time with time zone': 'timetz',
|
|
95
|
+
'bit varying': 'varbit',
|
|
96
|
+
};
|
|
97
|
+
const getNormalizedTypePg = (pgDataType) => typeNormalizationMap[pgDataType] || pgDataType;
|
|
98
|
+
exports.getNormalizedTypePg = getNormalizedTypePg;
|
|
99
|
+
//# sourceMappingURL=utils-pg.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils-pg.js","sourceRoot":"","sources":["../../../../src/pg/utils-pg.ts"],"names":[],"mappings":"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"}
|