drizzle-orm 0.10.21 → 0.10.24
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/LICENSE +674 -0
- package/{builders → dist/builders}/aggregators/abstractAggregator.d.ts +0 -0
- package/{builders → dist/builders}/aggregators/abstractAggregator.js +0 -0
- package/{builders → dist/builders}/aggregators/deleteAggregator.d.ts +0 -0
- package/{builders → dist/builders}/aggregators/deleteAggregator.js +4 -1
- package/{builders → dist/builders}/aggregators/insertAggregator.d.ts +0 -0
- package/{builders → dist/builders}/aggregators/insertAggregator.js +4 -1
- package/{builders → dist/builders}/aggregators/selectAggregator.d.ts +0 -0
- package/{builders → dist/builders}/aggregators/selectAggregator.js +24 -9
- package/{builders → dist/builders}/aggregators/updateAggregator.d.ts +0 -0
- package/{builders → dist/builders}/aggregators/updateAggregator.js +4 -1
- package/{builders → dist/builders}/highLvlBuilders/abstractRequestBuilder.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/abstractRequestBuilder.js +0 -0
- package/{builders → dist/builders}/highLvlBuilders/deleteRequestBuilder.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/deleteRequestBuilder.js +26 -4
- package/{builders → dist/builders}/highLvlBuilders/insertRequestBuilder.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/insertRequestBuilder.js +26 -4
- package/{builders → dist/builders}/highLvlBuilders/order.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/order.js +0 -0
- package/{builders → dist/builders}/highLvlBuilders/selectRequestBuilder.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/selectRequestBuilder.js +26 -4
- package/{builders → dist/builders}/highLvlBuilders/updateRequestBuilder.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/updateRequestBuilder.js +26 -4
- package/{builders → dist/builders}/index.d.ts +0 -0
- package/{builders → dist/builders}/index.js +19 -16
- package/{builders → dist/builders}/joinBuilders/builders/abstractJoinBuilder.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/abstractJoinBuilder.js +25 -3
- package/{builders → dist/builders}/joinBuilders/builders/selectWithFiveJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/selectWithFiveJoins.js +5 -2
- package/{builders → dist/builders}/joinBuilders/builders/selectWithFourJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/selectWithFourJoins.js +7 -4
- package/{builders → dist/builders}/joinBuilders/builders/selectWithJoin.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/selectWithJoin.js +7 -4
- package/{builders → dist/builders}/joinBuilders/builders/selectWithThreeJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/selectWithThreeJoins.js +7 -4
- package/{builders → dist/builders}/joinBuilders/builders/selectWithTwoJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/selectWithTwoJoins.js +7 -4
- package/{builders → dist/builders}/joinBuilders/join.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/join.js +0 -0
- package/{builders → dist/builders}/joinBuilders/joinWith.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/joinWith.js +4 -1
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseFiveJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseFiveJoins.js +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseFourJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseFourJoins.js +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseThreeJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseThreeJoins.js +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseTwoJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseTwoJoins.js +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseWithJoin.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseWithJoin.js +0 -0
- package/{builders → dist/builders}/joinBuilders/static.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/static.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/alter.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/alter.js +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/create.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/create.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/delets/delete.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/delets/delete.js +5 -2
- package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFilter.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFilter.js +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFrom.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFrom.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/inserts/insert.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/inserts/insert.js +5 -2
- package/{builders → dist/builders}/lowLvlBuilders/inserts/insertInto.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/inserts/insertInto.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/inserts/onConflictInsert.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/inserts/onConflictInsert.js +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/inserts/valuesInsert.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/inserts/valuesInsert.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/selects/select.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/selects/select.js +5 -2
- package/{builders → dist/builders}/lowLvlBuilders/selects/selectFrom.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/selects/selectFrom.js +5 -2
- package/{builders → dist/builders}/lowLvlBuilders/selects/selectJoined.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/selects/selectJoined.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/selects/whereSelect.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/selects/whereSelect.js +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/update.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/update.js +5 -2
- package/{builders → dist/builders}/lowLvlBuilders/updates/updateIn.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/updateIn.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/updates/whereSelect.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/whereSelect.js +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/whereSet.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/whereSet.js +4 -1
- package/{builders → dist/builders}/requestBuilders/updates/combine.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/combine.js +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/increment.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/increment.js +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/setObjects.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/setObjects.js +5 -2
- package/{builders → dist/builders}/requestBuilders/updates/static.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/static.js +6 -3
- package/{builders → dist/builders}/requestBuilders/updates/updates.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/updates.js +0 -0
- package/{builders → dist/builders}/requestBuilders/where/and.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/and.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/const.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/const.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/constArray.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/constArray.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/eqWhere.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/eqWhere.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/greater.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/greater.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/greaterEq.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/greaterEq.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/in.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/in.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/isNotNull.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/isNotNull.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/isNull.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/isNull.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/less.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/less.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/lessEq.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/lessEq.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/like.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/like.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/notEqWhere.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/notEqWhere.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/or.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/or.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/rawWhere.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/rawWhere.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/static.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/static.js +19 -16
- package/{builders → dist/builders}/requestBuilders/where/var.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/var.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/where.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/where.js +0 -0
- package/{builders → dist/builders}/transaction/transaction.d.ts +0 -0
- package/{builders → dist/builders}/transaction/transaction.js +0 -0
- package/{columns → dist/columns}/column.d.ts +0 -0
- package/{columns → dist/columns}/column.js +0 -0
- package/{columns → dist/columns}/index.d.ts +0 -0
- package/{columns → dist/columns}/index.js +12 -9
- package/{columns → dist/columns}/types/columnType.d.ts +0 -0
- package/{columns → dist/columns}/types/columnType.js +0 -0
- package/{columns → dist/columns}/types/pgBigDecimal.d.ts +0 -0
- package/{columns → dist/columns}/types/pgBigDecimal.js +4 -1
- package/{columns → dist/columns}/types/pgBigInt.d.ts +0 -0
- package/{columns → dist/columns}/types/pgBigInt.js +4 -1
- package/{columns → dist/columns}/types/pgBigSerial.d.ts +0 -0
- package/{columns → dist/columns}/types/pgBigSerial.js +4 -1
- package/{columns → dist/columns}/types/pgBoolean.d.ts +0 -0
- package/{columns → dist/columns}/types/pgBoolean.js +4 -1
- package/{columns → dist/columns}/types/pgEnum.d.ts +0 -0
- package/{columns → dist/columns}/types/pgEnum.js +4 -1
- package/{columns → dist/columns}/types/pgInteger.d.ts +0 -0
- package/{columns → dist/columns}/types/pgInteger.js +4 -1
- package/{columns → dist/columns}/types/pgJsonb.d.ts +0 -0
- package/{columns → dist/columns}/types/pgJsonb.js +4 -1
- package/{columns → dist/columns}/types/pgSerial.d.ts +0 -0
- package/{columns → dist/columns}/types/pgSerial.js +4 -1
- package/{columns → dist/columns}/types/pgSmallInt.d.ts +0 -0
- package/{columns → dist/columns}/types/pgSmallInt.js +4 -1
- package/{columns → dist/columns}/types/pgText.d.ts +0 -0
- package/{columns → dist/columns}/types/pgText.js +4 -1
- package/{columns → dist/columns}/types/pgTime.d.ts +0 -0
- package/{columns → dist/columns}/types/pgTime.js +4 -1
- package/{columns → dist/columns}/types/pgTimestamp.d.ts +0 -0
- package/{columns → dist/columns}/types/pgTimestamp.js +4 -1
- package/{columns → dist/columns}/types/pgTimestamptz.d.ts +0 -0
- package/{columns → dist/columns}/types/pgTimestamptz.js +4 -1
- package/{columns → dist/columns}/types/pgVarChar.d.ts +0 -0
- package/{columns → dist/columns}/types/pgVarChar.js +4 -1
- package/{db → dist/db}/db.d.ts +0 -0
- package/{db → dist/db}/db.js +0 -0
- package/{db → dist/db}/dbConnector.d.ts +0 -0
- package/{db → dist/db}/dbConnector.js +6 -3
- package/{db → dist/db}/dbStringConnector.d.ts +0 -0
- package/{db → dist/db}/dbStringConnector.js +5 -2
- package/{db → dist/db}/group_by.d.ts +0 -0
- package/{db → dist/db}/group_by.js +0 -0
- package/{db → dist/db}/index.d.ts +0 -0
- package/{db → dist/db}/index.js +6 -3
- package/{db → dist/db}/session.d.ts +0 -0
- package/{db → dist/db}/session.js +0 -0
- package/{docs → dist/docs}/cases/simple_delete.d.ts +0 -0
- package/{docs → dist/docs}/cases/simple_delete.js +7 -4
- package/{docs → dist/docs}/cases/simple_insert.d.ts +0 -0
- package/{docs → dist/docs}/cases/simple_insert.js +8 -5
- package/{docs → dist/docs}/cases/simple_join.d.ts +0 -0
- package/{docs → dist/docs}/cases/simple_join.js +8 -5
- package/{docs → dist/docs}/cases/simple_select.d.ts +0 -0
- package/{docs → dist/docs}/cases/simple_select.js +6 -3
- package/{docs → dist/docs}/cases/simple_update.d.ts +0 -0
- package/{docs → dist/docs}/cases/simple_update.js +7 -4
- package/{docs → dist/docs}/tables/citiesTable.d.ts +0 -0
- package/{docs → dist/docs}/tables/citiesTable.js +6 -2
- package/{docs → dist/docs}/tables/userGroupsTable.d.ts +0 -0
- package/{docs → dist/docs}/tables/userGroupsTable.js +4 -1
- package/{docs → dist/docs}/tables/usersTable.d.ts +0 -0
- package/{docs → dist/docs}/tables/usersTable.js +4 -1
- package/{docs → dist/docs}/tables/usersToUserGroups.d.ts +0 -0
- package/{docs → dist/docs}/tables/usersToUserGroups.js +6 -3
- package/{docs → dist/docs}/types/rolesType.d.ts +0 -0
- package/{docs → dist/docs}/types/rolesType.js +0 -0
- package/{errors → dist/errors}/baseError.d.ts +0 -0
- package/{errors → dist/errors}/baseError.js +0 -0
- package/{errors → dist/errors}/builderError.d.ts +0 -0
- package/{errors → dist/errors}/builderError.js +2 -1
- package/{errors → dist/errors}/dbErrors.d.ts +0 -0
- package/{errors → dist/errors}/dbErrors.js +0 -0
- package/{index.d.ts → dist/index.d.ts} +0 -0
- package/{index.js → dist/index.js} +4 -1
- package/{indexes → dist/indexes}/tableIndex.d.ts +0 -0
- package/{indexes → dist/indexes}/tableIndex.js +0 -0
- package/{logger → dist/logger}/abstractLogger.d.ts +0 -0
- package/{logger → dist/logger}/abstractLogger.js +0 -0
- package/{logger → dist/logger}/consoleLogger.d.ts +0 -0
- package/{logger → dist/logger}/consoleLogger.js +4 -1
- package/{mappers → dist/mappers}/index.d.ts +0 -0
- package/{mappers → dist/mappers}/index.js +0 -0
- package/{mappers → dist/mappers}/responseMapper.d.ts +0 -0
- package/{mappers → dist/mappers}/responseMapper.js +0 -0
- package/{migrator → dist/migrator}/index.d.ts +0 -0
- package/{migrator → dist/migrator}/index.js +0 -0
- package/{migrator → dist/migrator}/migrator.d.ts +0 -0
- package/{migrator → dist/migrator}/migrator.js +26 -4
- package/dist/serializer/serializer.d.ts +47 -0
- package/dist/serializer/serializer.js +258 -0
- package/dist/src/builders/aggregators/abstractAggregator.d.ts +11 -0
- package/dist/src/builders/aggregators/abstractAggregator.js +35 -0
- package/dist/src/builders/aggregators/deleteAggregator.d.ts +16 -0
- package/dist/src/builders/aggregators/deleteAggregator.js +42 -0
- package/dist/src/builders/aggregators/insertAggregator.d.ts +22 -0
- package/dist/src/builders/aggregators/insertAggregator.js +106 -0
- package/dist/src/builders/aggregators/selectAggregator.d.ts +39 -0
- package/dist/src/builders/aggregators/selectAggregator.js +143 -0
- package/dist/src/builders/aggregators/updateAggregator.d.ts +19 -0
- package/dist/src/builders/aggregators/updateAggregator.js +50 -0
- package/dist/src/builders/highLvlBuilders/abstractRequestBuilder.d.ts +27 -0
- package/dist/src/builders/highLvlBuilders/abstractRequestBuilder.js +32 -0
- package/dist/src/builders/highLvlBuilders/deleteRequestBuilder.d.ts +19 -0
- package/dist/src/builders/highLvlBuilders/deleteRequestBuilder.js +61 -0
- package/dist/src/builders/highLvlBuilders/insertRequestBuilder.d.ts +20 -0
- package/dist/src/builders/highLvlBuilders/insertRequestBuilder.js +73 -0
- package/dist/src/builders/highLvlBuilders/order.d.ts +5 -0
- package/dist/src/builders/highLvlBuilders/order.js +8 -0
- package/dist/src/builders/highLvlBuilders/selectRequestBuilder.d.ts +47 -0
- package/dist/src/builders/highLvlBuilders/selectRequestBuilder.js +128 -0
- package/dist/src/builders/highLvlBuilders/updateRequestBuilder.d.ts +22 -0
- package/dist/src/builders/highLvlBuilders/updateRequestBuilder.js +80 -0
- package/dist/src/builders/index.d.ts +18 -0
- package/dist/src/builders/index.js +54 -0
- package/dist/src/builders/joinBuilders/builders/abstractJoinBuilder.d.ts +40 -0
- package/dist/src/builders/joinBuilders/builders/abstractJoinBuilder.js +78 -0
- package/dist/src/builders/joinBuilders/builders/selectWithFiveJoins.d.ts +35 -0
- package/dist/src/builders/joinBuilders/builders/selectWithFiveJoins.js +45 -0
- package/dist/src/builders/joinBuilders/builders/selectWithFourJoins.d.ts +55 -0
- package/dist/src/builders/joinBuilders/builders/selectWithFourJoins.js +78 -0
- package/dist/src/builders/joinBuilders/builders/selectWithJoin.d.ts +49 -0
- package/dist/src/builders/joinBuilders/builders/selectWithJoin.js +64 -0
- package/dist/src/builders/joinBuilders/builders/selectWithThreeJoins.d.ts +53 -0
- package/dist/src/builders/joinBuilders/builders/selectWithThreeJoins.js +73 -0
- package/dist/src/builders/joinBuilders/builders/selectWithTwoJoins.d.ts +51 -0
- package/dist/src/builders/joinBuilders/builders/selectWithTwoJoins.js +68 -0
- package/dist/src/builders/joinBuilders/join.d.ts +23 -0
- package/dist/src/builders/joinBuilders/join.js +28 -0
- package/dist/src/builders/joinBuilders/joinWith.d.ts +14 -0
- package/dist/src/builders/joinBuilders/joinWith.js +14 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseFiveJoins.d.ts +20 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseFiveJoins.js +35 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseFourJoins.d.ts +19 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseFourJoins.js +34 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseThreeJoins.d.ts +18 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseThreeJoins.js +33 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseTwoJoins.d.ts +17 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseTwoJoins.js +32 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseWithJoin.d.ts +16 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseWithJoin.js +31 -0
- package/dist/src/builders/joinBuilders/static.d.ts +5 -0
- package/dist/src/builders/joinBuilders/static.js +9 -0
- package/dist/src/builders/lowLvlBuilders/alter.d.ts +0 -0
- package/dist/src/builders/lowLvlBuilders/alter.js +1 -0
- package/dist/src/builders/lowLvlBuilders/create.d.ts +12 -0
- package/dist/src/builders/lowLvlBuilders/create.js +100 -0
- package/dist/src/builders/lowLvlBuilders/delets/delete.d.ts +5 -0
- package/dist/src/builders/lowLvlBuilders/delets/delete.js +15 -0
- package/dist/src/builders/lowLvlBuilders/delets/deleteFilter.d.ts +11 -0
- package/dist/src/builders/lowLvlBuilders/delets/deleteFilter.js +13 -0
- package/dist/src/builders/lowLvlBuilders/delets/deleteFrom.d.ts +12 -0
- package/dist/src/builders/lowLvlBuilders/delets/deleteFrom.js +14 -0
- package/dist/src/builders/lowLvlBuilders/inserts/insert.d.ts +5 -0
- package/dist/src/builders/lowLvlBuilders/inserts/insert.js +15 -0
- package/dist/src/builders/lowLvlBuilders/inserts/insertInto.d.ts +13 -0
- package/dist/src/builders/lowLvlBuilders/inserts/insertInto.js +16 -0
- package/dist/src/builders/lowLvlBuilders/inserts/onConflictInsert.d.ts +12 -0
- package/dist/src/builders/lowLvlBuilders/inserts/onConflictInsert.js +13 -0
- package/dist/src/builders/lowLvlBuilders/inserts/valuesInsert.d.ts +16 -0
- package/dist/src/builders/lowLvlBuilders/inserts/valuesInsert.js +19 -0
- package/dist/src/builders/lowLvlBuilders/selects/select.d.ts +9 -0
- package/dist/src/builders/lowLvlBuilders/selects/select.js +16 -0
- package/dist/src/builders/lowLvlBuilders/selects/selectFrom.d.ts +28 -0
- package/dist/src/builders/lowLvlBuilders/selects/selectFrom.js +34 -0
- package/dist/src/builders/lowLvlBuilders/selects/selectJoined.d.ts +26 -0
- package/dist/src/builders/lowLvlBuilders/selects/selectJoined.js +30 -0
- package/dist/src/builders/lowLvlBuilders/selects/whereSelect.d.ts +17 -0
- package/dist/src/builders/lowLvlBuilders/selects/whereSelect.js +25 -0
- package/dist/src/builders/lowLvlBuilders/updates/update.d.ts +5 -0
- package/dist/src/builders/lowLvlBuilders/updates/update.js +15 -0
- package/dist/src/builders/lowLvlBuilders/updates/updateIn.d.ts +13 -0
- package/dist/src/builders/lowLvlBuilders/updates/updateIn.js +15 -0
- package/dist/src/builders/lowLvlBuilders/updates/whereSelect.d.ts +11 -0
- package/dist/src/builders/lowLvlBuilders/updates/whereSelect.js +13 -0
- package/dist/src/builders/lowLvlBuilders/updates/whereSet.d.ts +14 -0
- package/dist/src/builders/lowLvlBuilders/updates/whereSet.js +18 -0
- package/dist/src/builders/requestBuilders/updates/combine.d.ts +9 -0
- package/dist/src/builders/requestBuilders/updates/combine.js +26 -0
- package/dist/src/builders/requestBuilders/updates/increment.d.ts +13 -0
- package/dist/src/builders/requestBuilders/updates/increment.js +18 -0
- package/dist/src/builders/requestBuilders/updates/setObjects.d.ts +12 -0
- package/dist/src/builders/requestBuilders/updates/setObjects.js +19 -0
- package/dist/src/builders/requestBuilders/updates/static.d.ts +7 -0
- package/dist/src/builders/requestBuilders/updates/static.js +15 -0
- package/dist/src/builders/requestBuilders/updates/updates.d.ts +9 -0
- package/dist/src/builders/requestBuilders/updates/updates.js +10 -0
- package/dist/src/builders/requestBuilders/where/and.d.ts +11 -0
- package/dist/src/builders/requestBuilders/where/and.js +31 -0
- package/dist/src/builders/requestBuilders/where/const.d.ts +9 -0
- package/dist/src/builders/requestBuilders/where/const.js +25 -0
- package/dist/src/builders/requestBuilders/where/constArray.d.ts +9 -0
- package/dist/src/builders/requestBuilders/where/constArray.js +39 -0
- package/dist/src/builders/requestBuilders/where/eqWhere.d.ts +12 -0
- package/dist/src/builders/requestBuilders/where/eqWhere.js +20 -0
- package/dist/src/builders/requestBuilders/where/greater.d.ts +15 -0
- package/dist/src/builders/requestBuilders/where/greater.js +20 -0
- package/dist/src/builders/requestBuilders/where/greaterEq.d.ts +15 -0
- package/dist/src/builders/requestBuilders/where/greaterEq.js +20 -0
- package/dist/src/builders/requestBuilders/where/in.d.ts +12 -0
- package/dist/src/builders/requestBuilders/where/in.js +20 -0
- package/dist/src/builders/requestBuilders/where/isNotNull.d.ts +11 -0
- package/dist/src/builders/requestBuilders/where/isNotNull.js +18 -0
- package/dist/src/builders/requestBuilders/where/isNull.d.ts +11 -0
- package/dist/src/builders/requestBuilders/where/isNull.js +18 -0
- package/dist/src/builders/requestBuilders/where/less.d.ts +15 -0
- package/dist/src/builders/requestBuilders/where/less.js +20 -0
- package/dist/src/builders/requestBuilders/where/lessEq.d.ts +15 -0
- package/dist/src/builders/requestBuilders/where/lessEq.js +20 -0
- package/dist/src/builders/requestBuilders/where/like.d.ts +12 -0
- package/dist/src/builders/requestBuilders/where/like.js +20 -0
- package/dist/src/builders/requestBuilders/where/notEqWhere.d.ts +12 -0
- package/dist/src/builders/requestBuilders/where/notEqWhere.js +20 -0
- package/dist/src/builders/requestBuilders/where/or.d.ts +11 -0
- package/dist/src/builders/requestBuilders/where/or.js +31 -0
- package/dist/src/builders/requestBuilders/where/rawWhere.d.ts +9 -0
- package/dist/src/builders/requestBuilders/where/rawWhere.js +15 -0
- package/dist/src/builders/requestBuilders/where/static.d.ts +17 -0
- package/dist/src/builders/requestBuilders/where/static.js +49 -0
- package/dist/src/builders/requestBuilders/where/var.d.ts +13 -0
- package/dist/src/builders/requestBuilders/where/var.js +18 -0
- package/dist/src/builders/requestBuilders/where/where.d.ts +8 -0
- package/dist/src/builders/requestBuilders/where/where.js +6 -0
- package/dist/src/builders/transaction/transaction.d.ts +8 -0
- package/dist/src/builders/transaction/transaction.js +20 -0
- package/dist/src/columns/column.d.ts +72 -0
- package/dist/src/columns/column.js +101 -0
- package/dist/src/columns/index.d.ts +10 -0
- package/dist/src/columns/index.js +27 -0
- package/dist/src/columns/types/columnType.d.ts +7 -0
- package/dist/src/columns/types/columnType.js +6 -0
- package/dist/src/columns/types/pgBigDecimal.d.ts +10 -0
- package/dist/src/columns/types/pgBigDecimal.js +31 -0
- package/dist/src/columns/types/pgBigInt.d.ts +15 -0
- package/dist/src/columns/types/pgBigInt.js +32 -0
- package/dist/src/columns/types/pgBigSerial.d.ts +15 -0
- package/dist/src/columns/types/pgBigSerial.js +32 -0
- package/dist/src/columns/types/pgBoolean.d.ts +8 -0
- package/dist/src/columns/types/pgBoolean.js +18 -0
- package/dist/src/columns/types/pgEnum.d.ts +9 -0
- package/dist/src/columns/types/pgEnum.js +18 -0
- package/dist/src/columns/types/pgInteger.d.ts +8 -0
- package/dist/src/columns/types/pgInteger.js +21 -0
- package/dist/src/columns/types/pgJsonb.d.ts +9 -0
- package/dist/src/columns/types/pgJsonb.js +20 -0
- package/dist/src/columns/types/pgSerial.d.ts +8 -0
- package/dist/src/columns/types/pgSerial.js +18 -0
- package/dist/src/columns/types/pgSmallInt.d.ts +8 -0
- package/dist/src/columns/types/pgSmallInt.js +18 -0
- package/dist/src/columns/types/pgText.d.ts +8 -0
- package/dist/src/columns/types/pgText.js +18 -0
- package/dist/src/columns/types/pgTime.d.ts +8 -0
- package/dist/src/columns/types/pgTime.js +18 -0
- package/dist/src/columns/types/pgTimestamp.d.ts +8 -0
- package/dist/src/columns/types/pgTimestamp.js +18 -0
- package/dist/src/columns/types/pgTimestamptz.d.ts +8 -0
- package/dist/src/columns/types/pgTimestamptz.js +18 -0
- package/dist/src/columns/types/pgVarChar.d.ts +9 -0
- package/dist/src/columns/types/pgVarChar.js +24 -0
- package/dist/src/db/db.d.ts +18 -0
- package/dist/src/db/db.js +25 -0
- package/dist/src/db/dbConnector.d.ts +9 -0
- package/dist/src/db/dbConnector.js +32 -0
- package/dist/src/db/dbStringConnector.d.ts +6 -0
- package/dist/src/db/dbStringConnector.js +29 -0
- package/dist/src/db/group_by.d.ts +0 -0
- package/dist/src/db/group_by.js +68 -0
- package/dist/src/db/index.d.ts +4 -0
- package/dist/src/db/index.js +14 -0
- package/dist/src/db/session.d.ts +9 -0
- package/dist/src/db/session.js +16 -0
- package/{test.d.ts → dist/src/docs/cases/simple_delete.d.ts} +0 -0
- package/dist/src/docs/cases/simple_delete.js +35 -0
- package/dist/src/docs/cases/simple_insert.d.ts +1 -0
- package/dist/src/docs/cases/simple_insert.js +57 -0
- package/dist/src/docs/cases/simple_join.d.ts +1 -0
- package/dist/src/docs/cases/simple_join.js +115 -0
- package/dist/src/docs/cases/simple_select.d.ts +1 -0
- package/dist/src/docs/cases/simple_select.js +50 -0
- package/dist/src/docs/cases/simple_update.d.ts +1 -0
- package/dist/src/docs/cases/simple_update.js +39 -0
- package/dist/src/docs/tables/citiesTable.d.ts +14 -0
- package/dist/src/docs/tables/citiesTable.js +21 -0
- package/dist/src/docs/tables/userGroupsTable.d.ts +7 -0
- package/dist/src/docs/tables/userGroupsTable.js +18 -0
- package/dist/src/docs/tables/usersTable.d.ts +17 -0
- package/dist/src/docs/tables/usersTable.js +35 -0
- package/dist/src/docs/tables/usersToUserGroups.d.ts +7 -0
- package/dist/src/docs/tables/usersToUserGroups.js +20 -0
- package/dist/src/docs/types/rolesType.d.ts +1 -0
- package/dist/src/docs/types/rolesType.js +6 -0
- package/dist/src/errors/baseError.d.ts +22 -0
- package/dist/src/errors/baseError.js +35 -0
- package/dist/src/errors/builderError.d.ts +14 -0
- package/dist/src/errors/builderError.js +25 -0
- package/dist/src/errors/dbErrors.d.ts +12 -0
- package/dist/src/errors/dbErrors.js +28 -0
- package/dist/src/index.d.ts +11 -0
- package/dist/src/index.js +31 -0
- package/dist/src/indexes/tableIndex.d.ts +11 -0
- package/dist/src/indexes/tableIndex.js +17 -0
- package/dist/src/logger/abstractLogger.d.ts +4 -0
- package/dist/src/logger/abstractLogger.js +5 -0
- package/dist/src/logger/consoleLogger.d.ts +5 -0
- package/dist/src/logger/consoleLogger.js +15 -0
- package/dist/src/mappers/index.d.ts +0 -0
- package/dist/src/mappers/index.js +1 -0
- package/dist/src/mappers/responseMapper.d.ts +10 -0
- package/dist/src/mappers/responseMapper.js +35 -0
- package/dist/src/migrator/index.d.ts +0 -0
- package/dist/src/migrator/index.js +1 -0
- package/dist/src/migrator/migrator.d.ts +11 -0
- package/dist/src/migrator/migrator.js +105 -0
- package/{serializer → dist/src/serializer}/serializer.d.ts +0 -0
- package/{serializer → dist/src/serializer}/serializer.js +4 -1
- package/{tables → dist/src/tables}/abstractTable.d.ts +0 -0
- package/{tables → dist/src/tables}/abstractTable.js +41 -19
- package/{tables → dist/src/tables}/index.d.ts +0 -0
- package/{tables → dist/src/tables}/index.js +5 -2
- package/{tables → dist/src/tables}/inferTypes.d.ts +0 -0
- package/{tables → dist/src/tables}/inferTypes.js +0 -0
- package/{tables → dist/src/tables}/migrationsTable.d.ts +0 -0
- package/{tables → dist/src/tables}/migrationsTable.js +4 -1
- package/dist/src/test.d.ts +1 -0
- package/{test.js → dist/src/test.js} +23 -8
- package/{types → dist/src/types}/type.d.ts +0 -0
- package/{types → dist/src/types}/type.js +0 -0
- package/{utils → dist/src/utils}/ecranate.d.ts +0 -0
- package/{utils → dist/src/utils}/ecranate.js +0 -0
- package/dist/tables/abstractTable.d.ts +68 -0
- package/dist/tables/abstractTable.js +151 -0
- package/dist/tables/index.d.ts +3 -0
- package/dist/tables/index.js +11 -0
- package/dist/tables/inferTypes.d.ts +39 -0
- package/dist/tables/inferTypes.js +2 -0
- package/dist/tables/migrationsTable.d.ts +7 -0
- package/dist/tables/migrationsTable.js +18 -0
- package/dist/test.d.ts +1 -0
- package/dist/test.js +65 -0
- package/dist/tsconfig.tsbuildinfo +5054 -0
- package/dist/types/type.d.ts +10 -0
- package/dist/types/type.js +14 -0
- package/dist/utils/ecranate.d.ts +2 -0
- package/dist/utils/ecranate.js +8 -0
- package/package.json +18 -13
- package/tables/aggregators.d.ts +0 -27
- package/tables/aggregators.js +0 -56
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const ecranate_1 = require("../../utils/ecranate");
|
|
7
|
+
const order_1 = __importDefault(require("../highLvlBuilders/order"));
|
|
8
|
+
const abstractAggregator_1 = __importDefault(require("./abstractAggregator"));
|
|
9
|
+
class SelectAggregator extends abstractAggregator_1.default {
|
|
10
|
+
// public constructor(table: AbstractTable<any>);
|
|
11
|
+
// public constructor(table: AbstractTable<any>, partial: {[name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, AbstractTable<any>>})
|
|
12
|
+
constructor(table, partial) {
|
|
13
|
+
super(table, partial);
|
|
14
|
+
this._from = [];
|
|
15
|
+
this._filters = [];
|
|
16
|
+
this._select = ['SELECT'];
|
|
17
|
+
this._join = [];
|
|
18
|
+
this._limit = [];
|
|
19
|
+
this._offset = [];
|
|
20
|
+
this._distinct = [];
|
|
21
|
+
// private _groupBy: Array<string> = [];
|
|
22
|
+
this._orderBy = [];
|
|
23
|
+
this._values = [];
|
|
24
|
+
this._joinCache = {};
|
|
25
|
+
this.filters = (filters) => {
|
|
26
|
+
if (filters) {
|
|
27
|
+
const queryBuilder = filters.toQuery(1, this._joinCache);
|
|
28
|
+
this._filters.push('WHERE ');
|
|
29
|
+
this._filters.push(queryBuilder.query);
|
|
30
|
+
this._values = queryBuilder.values;
|
|
31
|
+
}
|
|
32
|
+
return this;
|
|
33
|
+
};
|
|
34
|
+
this.limit = (limit) => {
|
|
35
|
+
if (limit) {
|
|
36
|
+
this._limit.push('LIMIT ');
|
|
37
|
+
this._limit.push(limit.toString());
|
|
38
|
+
}
|
|
39
|
+
return this;
|
|
40
|
+
};
|
|
41
|
+
this.offset = (offset) => {
|
|
42
|
+
if (offset) {
|
|
43
|
+
this._offset.push('OFFSET ');
|
|
44
|
+
this._offset.push(offset.toString());
|
|
45
|
+
}
|
|
46
|
+
return this;
|
|
47
|
+
};
|
|
48
|
+
this.orderBy = (column, order) => {
|
|
49
|
+
if (column !== null && column !== undefined) {
|
|
50
|
+
this._orderBy.push('ORDER BY ');
|
|
51
|
+
const columnParent = this._joinCache[column.getParent().tableName()] ? this._joinCache[column.getParent().tableName()] : column.getParent().tableName();
|
|
52
|
+
this._orderBy.push(`${columnParent}.${ecranate_1.ecranate(column.getColumnName())} `);
|
|
53
|
+
this._orderBy.push(order_1.default[order]);
|
|
54
|
+
}
|
|
55
|
+
return this;
|
|
56
|
+
};
|
|
57
|
+
this.distinct = (column) => {
|
|
58
|
+
if (column) {
|
|
59
|
+
this._distinct.push(` DISTINCT ON(${column.getParent().tableName()}.${ecranate_1.ecranate(column.getColumnName())}) `);
|
|
60
|
+
}
|
|
61
|
+
return this;
|
|
62
|
+
};
|
|
63
|
+
this.appendFrom = (tableName) => {
|
|
64
|
+
this._from.push('FROM ');
|
|
65
|
+
this._from.push(tableName);
|
|
66
|
+
// this._from.push(`${tableName} AS ${tableName}_0`);
|
|
67
|
+
this._joinCache[tableName] = tableName;
|
|
68
|
+
return this;
|
|
69
|
+
};
|
|
70
|
+
// Add select generator for second table also
|
|
71
|
+
this.join = (joins) => {
|
|
72
|
+
// const cache: {[tableName: string]: string} = {};
|
|
73
|
+
joins.forEach((joinObject) => {
|
|
74
|
+
if (joinObject) {
|
|
75
|
+
const tableFrom = joinObject.join.fromColumn.getParentName();
|
|
76
|
+
const tableTo = joinObject.join.toColumn.getParentName();
|
|
77
|
+
const { type } = joinObject.join;
|
|
78
|
+
let fromAlias = '';
|
|
79
|
+
if (this._joinCache[tableFrom]) {
|
|
80
|
+
fromAlias = this._joinCache[tableFrom];
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
fromAlias = `${tableFrom}${joinObject.id ? `_${joinObject.id}` : ''}`;
|
|
84
|
+
this._joinCache[tableFrom] = fromAlias;
|
|
85
|
+
}
|
|
86
|
+
let selectString;
|
|
87
|
+
if (joinObject.partial) {
|
|
88
|
+
selectString = this.generateSelectArray(`${tableTo}${joinObject.id ? `_${joinObject.id}` : ''}`, Object.values(joinObject.partial), joinObject.id).join('');
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
selectString = this.generateSelectArray(`${tableTo}${joinObject.id ? `_${joinObject.id}` : ''}`, Object.values(joinObject.join.mappedServiceToDb), joinObject.id).join('');
|
|
92
|
+
}
|
|
93
|
+
this._fields.push(', ');
|
|
94
|
+
this._fields.push(selectString);
|
|
95
|
+
this._join.push('\n');
|
|
96
|
+
this._join.push(type);
|
|
97
|
+
this._join.push(' ');
|
|
98
|
+
this._join.push(tableTo);
|
|
99
|
+
this._join.push(' ');
|
|
100
|
+
this._join.push(`AS ${tableTo}${joinObject.id ? `_${joinObject.id}` : ''}`);
|
|
101
|
+
this._joinCache[tableTo] = `${tableTo}${joinObject.id ? `_${joinObject.id}` : ''}`;
|
|
102
|
+
this._join.push('\n');
|
|
103
|
+
this._join.push('ON ');
|
|
104
|
+
this._join.push(fromAlias);
|
|
105
|
+
// if (this._joinCache[tableFrom]) {
|
|
106
|
+
// this._join.push(this._joinCache[tableFrom]);
|
|
107
|
+
// } else {
|
|
108
|
+
// this._join.push(tableFrom);
|
|
109
|
+
// this._joinCache[tableFrom] = `${tableFrom}${joinObject.id ? `_${joinObject.id}` : ''}`;
|
|
110
|
+
// }
|
|
111
|
+
this._join.push('.');
|
|
112
|
+
this._join.push(joinObject.join.fromColumn.getColumnName());
|
|
113
|
+
this._join.push(' = ');
|
|
114
|
+
this._join.push(`${tableTo}${joinObject.id ? `_${joinObject.id}` : ''}`);
|
|
115
|
+
// this._join.push(toAlias);
|
|
116
|
+
this._join.push('.');
|
|
117
|
+
this._join.push(joinObject.join.toColumn.getColumnName());
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
return this;
|
|
121
|
+
};
|
|
122
|
+
this.buildQuery = () => {
|
|
123
|
+
this._select.push(this._distinct.join(''));
|
|
124
|
+
this._select.push(this._fields.join(''));
|
|
125
|
+
this._select.push('\n');
|
|
126
|
+
this._select.push(this._from.join(''));
|
|
127
|
+
this._select.push('\n');
|
|
128
|
+
this._select.push(this._join.join(''));
|
|
129
|
+
if (this._join.length > 0) {
|
|
130
|
+
this._select.push('\n');
|
|
131
|
+
}
|
|
132
|
+
this._select.push(this._filters.join(''));
|
|
133
|
+
this._select.push('\n');
|
|
134
|
+
this._select.push(this._orderBy.join(''));
|
|
135
|
+
this._select.push('\n');
|
|
136
|
+
this._select.push(this._limit.join(''));
|
|
137
|
+
this._select.push('\n');
|
|
138
|
+
this._select.push(this._offset.join(''));
|
|
139
|
+
return { query: this._select.join(''), values: this._values };
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
exports.default = SelectAggregator;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { AbstractTable } from '../../tables';
|
|
2
|
+
import { UpdateExpr } from '../requestBuilders/updates/updates';
|
|
3
|
+
import Expr from '../requestBuilders/where/where';
|
|
4
|
+
import Aggregator from './abstractAggregator';
|
|
5
|
+
export default class UpdateAggregator extends Aggregator {
|
|
6
|
+
private _updates;
|
|
7
|
+
private _filters;
|
|
8
|
+
private _from;
|
|
9
|
+
private _values;
|
|
10
|
+
private _update;
|
|
11
|
+
constructor(table: AbstractTable<any>);
|
|
12
|
+
where: (filters: Expr) => UpdateAggregator;
|
|
13
|
+
appendFrom: (tableName: string) => UpdateAggregator;
|
|
14
|
+
set: (updates: UpdateExpr) => UpdateAggregator;
|
|
15
|
+
buildQuery: () => {
|
|
16
|
+
query: string;
|
|
17
|
+
values: Array<any>;
|
|
18
|
+
};
|
|
19
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const abstractAggregator_1 = __importDefault(require("./abstractAggregator"));
|
|
7
|
+
class UpdateAggregator extends abstractAggregator_1.default {
|
|
8
|
+
constructor(table) {
|
|
9
|
+
super(table);
|
|
10
|
+
this._updates = [];
|
|
11
|
+
this._filters = [];
|
|
12
|
+
this._from = [];
|
|
13
|
+
this._values = [];
|
|
14
|
+
this._update = ['UPDATE'];
|
|
15
|
+
this.where = (filters) => {
|
|
16
|
+
if (filters) {
|
|
17
|
+
const currentPointerPosition = this._values.length > 0 ? this._values.length + 1 : undefined;
|
|
18
|
+
const filterQuery = filters.toQuery(currentPointerPosition);
|
|
19
|
+
this._filters.push('WHERE ');
|
|
20
|
+
this._filters.push(filterQuery.query);
|
|
21
|
+
this._values.push(...filterQuery.values);
|
|
22
|
+
}
|
|
23
|
+
return this;
|
|
24
|
+
};
|
|
25
|
+
this.appendFrom = (tableName) => {
|
|
26
|
+
this._from.push(' ');
|
|
27
|
+
this._from.push(tableName);
|
|
28
|
+
return this;
|
|
29
|
+
};
|
|
30
|
+
this.set = (updates) => {
|
|
31
|
+
const setQuery = updates.toQuery();
|
|
32
|
+
this._updates.push(`\nSET ${setQuery.query}`);
|
|
33
|
+
this._values.push(...setQuery.values);
|
|
34
|
+
return this;
|
|
35
|
+
};
|
|
36
|
+
this.buildQuery = () => {
|
|
37
|
+
this._update.push(this._from.join(''));
|
|
38
|
+
this._update.push('\n');
|
|
39
|
+
this._update.push(this._updates.join(''));
|
|
40
|
+
this._update.push('\n');
|
|
41
|
+
this._update.push(this._filters.join(''));
|
|
42
|
+
this._update.push('\n');
|
|
43
|
+
this._update.push('RETURNING');
|
|
44
|
+
this._update.push('\n');
|
|
45
|
+
this._update.push(this._fields.join(''));
|
|
46
|
+
return { query: this._update.join(''), values: this._values };
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
exports.default = UpdateAggregator;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { AbstractColumn } from '../../columns/column';
|
|
2
|
+
import ColumnType from '../../columns/types/columnType';
|
|
3
|
+
import { ISession } from '../../db/session';
|
|
4
|
+
import BaseLogger from '../../logger/abstractLogger';
|
|
5
|
+
import { AbstractTable } from '../../tables';
|
|
6
|
+
import { ExtractModel } from '../../tables/inferTypes';
|
|
7
|
+
export default abstract class TableRequestBuilder<TTable extends AbstractTable<TTable>, TPartial extends {
|
|
8
|
+
[name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, TTable>;
|
|
9
|
+
} = {}> {
|
|
10
|
+
protected _table: TTable;
|
|
11
|
+
protected _session: ISession;
|
|
12
|
+
protected _mappedServiceToDb: {
|
|
13
|
+
[name in keyof ExtractModel<TTable>]: AbstractColumn<ColumnType>;
|
|
14
|
+
};
|
|
15
|
+
protected _columns: AbstractColumn<ColumnType>[];
|
|
16
|
+
protected _logger?: BaseLogger;
|
|
17
|
+
constructor(table: AbstractTable<TTable>, session: ISession, mappedServiceToDb: {
|
|
18
|
+
[name in keyof ExtractModel<TTable>]: AbstractColumn<ColumnType>;
|
|
19
|
+
}, logger?: BaseLogger);
|
|
20
|
+
all: () => Promise<([keyof TPartial] extends [never] ? ExtractModel<TTable> : ExtractModel<TPartial>)[]>;
|
|
21
|
+
/**
|
|
22
|
+
* Current function will return an element only if response is of length 1
|
|
23
|
+
* If there are more or less than 1 element, will throw an Error
|
|
24
|
+
*/
|
|
25
|
+
findOne: () => Promise<[keyof TPartial] extends [never] ? ExtractModel<TTable> : ExtractModel<TPartial>>;
|
|
26
|
+
protected abstract _execute(): Promise<Array<[keyof TPartial] extends [never] ? ExtractModel<TTable> : ExtractModel<TPartial>>>;
|
|
27
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
class TableRequestBuilder {
|
|
4
|
+
constructor(table, session, mappedServiceToDb, logger) {
|
|
5
|
+
this.all = async () => {
|
|
6
|
+
const res = await this._execute();
|
|
7
|
+
return res;
|
|
8
|
+
};
|
|
9
|
+
/**
|
|
10
|
+
* Current function will return an element only if response is of length 1
|
|
11
|
+
* If there are more or less than 1 element, will throw an Error
|
|
12
|
+
*/
|
|
13
|
+
this.findOne = async () => {
|
|
14
|
+
const executionRes = await this._execute();
|
|
15
|
+
if (executionRes.length > 1) {
|
|
16
|
+
throw new Error('Request contains more than 1 element');
|
|
17
|
+
}
|
|
18
|
+
else if (executionRes.length < 1) {
|
|
19
|
+
throw new Error('Request contains less than 1 element ');
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
return executionRes[0];
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
this._mappedServiceToDb = mappedServiceToDb;
|
|
26
|
+
this._table = table;
|
|
27
|
+
this._session = session;
|
|
28
|
+
this._columns = Object.values(mappedServiceToDb);
|
|
29
|
+
this._logger = logger;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
exports.default = TableRequestBuilder;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { AbstractColumn } from '../../columns/column';
|
|
2
|
+
import ColumnType from '../../columns/types/columnType';
|
|
3
|
+
import { ISession } from '../../db/session';
|
|
4
|
+
import BaseLogger from '../../logger/abstractLogger';
|
|
5
|
+
import { AbstractTable } from '../../tables';
|
|
6
|
+
import { ExtractModel } from '../../tables/inferTypes';
|
|
7
|
+
import Expr from '../requestBuilders/where/where';
|
|
8
|
+
import TableRequestBuilder from './abstractRequestBuilder';
|
|
9
|
+
export default class DeleteTRB<TTable extends AbstractTable<TTable>, TPartial extends {
|
|
10
|
+
[name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, TTable>;
|
|
11
|
+
} = {}> extends TableRequestBuilder<TTable, TPartial> {
|
|
12
|
+
private _filter;
|
|
13
|
+
constructor(table: AbstractTable<TTable>, session: ISession, mappedServiceToDb: {
|
|
14
|
+
[name in keyof ExtractModel<TTable>]: AbstractColumn<ColumnType>;
|
|
15
|
+
}, logger?: BaseLogger);
|
|
16
|
+
where: (expr: Expr) => DeleteTRB<TTable>;
|
|
17
|
+
execute: () => Promise<void>;
|
|
18
|
+
protected _execute: () => Promise<Array<[keyof TPartial] extends [never] ? ExtractModel<TTable> : ExtractModel<TPartial>>>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
22
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
|
+
};
|
|
24
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
+
const builderError_1 = __importStar(require("../../errors/builderError"));
|
|
26
|
+
const responseMapper_1 = __importDefault(require("../../mappers/responseMapper"));
|
|
27
|
+
const delete_1 = __importDefault(require("../lowLvlBuilders/delets/delete"));
|
|
28
|
+
const abstractRequestBuilder_1 = __importDefault(require("./abstractRequestBuilder"));
|
|
29
|
+
class DeleteTRB extends abstractRequestBuilder_1.default {
|
|
30
|
+
constructor(table, session, mappedServiceToDb, logger) {
|
|
31
|
+
super(table, session, mappedServiceToDb, logger);
|
|
32
|
+
this.where = (expr) => {
|
|
33
|
+
this._filter = expr;
|
|
34
|
+
return this;
|
|
35
|
+
};
|
|
36
|
+
this.execute = async () => {
|
|
37
|
+
await this._execute();
|
|
38
|
+
};
|
|
39
|
+
this._execute = async () => {
|
|
40
|
+
const queryBuilder = delete_1.default
|
|
41
|
+
.from(this._table)
|
|
42
|
+
.filteredBy(this._filter);
|
|
43
|
+
let query = '';
|
|
44
|
+
let values = [];
|
|
45
|
+
try {
|
|
46
|
+
const builderResult = queryBuilder.build();
|
|
47
|
+
query = builderResult.query;
|
|
48
|
+
values = builderResult.values;
|
|
49
|
+
}
|
|
50
|
+
catch (e) {
|
|
51
|
+
throw new builderError_1.default(builderError_1.BuilderType.DELETE, this._table.tableName(), this._columns, e, this._filter);
|
|
52
|
+
}
|
|
53
|
+
if (this._logger) {
|
|
54
|
+
this._logger.info(`Deleting from ${this._table.tableName()} using query:\n ${query}`);
|
|
55
|
+
}
|
|
56
|
+
const result = await this._session.execute(query, values);
|
|
57
|
+
return responseMapper_1.default.map(this._mappedServiceToDb, result);
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
exports.default = DeleteTRB;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { AbstractColumn } from '../../columns/column';
|
|
2
|
+
import ColumnType from '../../columns/types/columnType';
|
|
3
|
+
import { ISession } from '../../db/session';
|
|
4
|
+
import BaseLogger from '../../logger/abstractLogger';
|
|
5
|
+
import { AbstractTable } from '../../tables';
|
|
6
|
+
import { ExtractModel, Indexing } from '../../tables/inferTypes';
|
|
7
|
+
import TableRequestBuilder from './abstractRequestBuilder';
|
|
8
|
+
export default class InsertTRB<TTable extends AbstractTable<TTable>, TPartial extends {
|
|
9
|
+
[name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, TTable>;
|
|
10
|
+
} = {}> extends TableRequestBuilder<TTable, TPartial> {
|
|
11
|
+
private _values;
|
|
12
|
+
private _onConflict;
|
|
13
|
+
private _onConflictField;
|
|
14
|
+
constructor(values: ExtractModel<TTable>[], session: ISession, mappedServiceToDb: {
|
|
15
|
+
[name in keyof ExtractModel<TTable>]: AbstractColumn<ColumnType>;
|
|
16
|
+
}, table: AbstractTable<TTable>, logger?: BaseLogger);
|
|
17
|
+
execute: () => Promise<void>;
|
|
18
|
+
onConflict: (callback: (table: TTable) => Indexing, update: Partial<ExtractModel<TTable>>) => InsertTRB<TTable>;
|
|
19
|
+
protected _execute: () => Promise<Array<[keyof TPartial] extends [never] ? ExtractModel<TTable> : ExtractModel<TPartial>>>;
|
|
20
|
+
}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
22
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
|
+
};
|
|
24
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
+
/* eslint-disable max-len */
|
|
26
|
+
const __1 = require("..");
|
|
27
|
+
const builderError_1 = __importStar(require("../../errors/builderError"));
|
|
28
|
+
const responseMapper_1 = __importDefault(require("../../mappers/responseMapper"));
|
|
29
|
+
const insert_1 = __importDefault(require("../lowLvlBuilders/inserts/insert"));
|
|
30
|
+
const abstractRequestBuilder_1 = __importDefault(require("./abstractRequestBuilder"));
|
|
31
|
+
class InsertTRB extends abstractRequestBuilder_1.default {
|
|
32
|
+
constructor(values, session, mappedServiceToDb, table, logger) {
|
|
33
|
+
super(table, session, mappedServiceToDb, logger);
|
|
34
|
+
this.execute = async () => {
|
|
35
|
+
await this._execute();
|
|
36
|
+
};
|
|
37
|
+
this.onConflict = (callback, update) => {
|
|
38
|
+
this._onConflictField = callback(this._table);
|
|
39
|
+
const updates = [];
|
|
40
|
+
Object.entries(update).forEach(([key, value]) => {
|
|
41
|
+
const column = this._mappedServiceToDb[key];
|
|
42
|
+
updates.push(__1.set(column, value));
|
|
43
|
+
});
|
|
44
|
+
this._onConflict = __1.combine(updates);
|
|
45
|
+
return this;
|
|
46
|
+
};
|
|
47
|
+
this._execute = async () => {
|
|
48
|
+
if (!this._values)
|
|
49
|
+
throw Error('Values should be provided firestly\nExample: table.values().execute()');
|
|
50
|
+
const queryBuilder = insert_1.default
|
|
51
|
+
.into(this._table)
|
|
52
|
+
.values(this._values)
|
|
53
|
+
.onConflict(this._onConflict, this._onConflictField);
|
|
54
|
+
let query = '';
|
|
55
|
+
let values = [];
|
|
56
|
+
try {
|
|
57
|
+
const builderResult = queryBuilder.build();
|
|
58
|
+
query = builderResult.query;
|
|
59
|
+
values = builderResult.values;
|
|
60
|
+
}
|
|
61
|
+
catch (e) {
|
|
62
|
+
throw new builderError_1.default(builderError_1.BuilderType.INSERT, this._table.tableName(), this._columns, e);
|
|
63
|
+
}
|
|
64
|
+
if (this._logger) {
|
|
65
|
+
this._logger.info(`Inserting to ${this._table.tableName()} using query:\n ${query}\n${values}`);
|
|
66
|
+
}
|
|
67
|
+
const result = await this._session.execute(query, values);
|
|
68
|
+
return responseMapper_1.default.map(this._mappedServiceToDb, result);
|
|
69
|
+
};
|
|
70
|
+
this._values = values;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
exports.default = InsertTRB;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { AbstractColumn } from '../../columns/column';
|
|
2
|
+
import ColumnType from '../../columns/types/columnType';
|
|
3
|
+
import DB from '../../db/db';
|
|
4
|
+
import { ISession } from '../../db/session';
|
|
5
|
+
import BaseLogger from '../../logger/abstractLogger';
|
|
6
|
+
import { AbstractTable } from '../../tables';
|
|
7
|
+
import { ExtractModel, PartialFor } from '../../tables/inferTypes';
|
|
8
|
+
import SelectTRBWithJoin from '../joinBuilders/builders/selectWithJoin';
|
|
9
|
+
import Expr from '../requestBuilders/where/where';
|
|
10
|
+
import TableRequestBuilder from './abstractRequestBuilder';
|
|
11
|
+
import Order from './order';
|
|
12
|
+
export default class SelectTRB<TTable extends AbstractTable<TTable>, TPartial extends {
|
|
13
|
+
[name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, TTable>;
|
|
14
|
+
} = {}> extends TableRequestBuilder<TTable, TPartial> {
|
|
15
|
+
protected _filter: Expr;
|
|
16
|
+
private props;
|
|
17
|
+
private __orderBy?;
|
|
18
|
+
private __groupBy?;
|
|
19
|
+
private __order?;
|
|
20
|
+
private __distinct;
|
|
21
|
+
private __partial?;
|
|
22
|
+
constructor(session: ISession, mappedServiceToDb: {
|
|
23
|
+
[name in keyof ExtractModel<TTable>]: AbstractColumn<ColumnType>;
|
|
24
|
+
}, props: {
|
|
25
|
+
limit?: number;
|
|
26
|
+
offset?: number;
|
|
27
|
+
}, table: AbstractTable<TTable>, logger?: BaseLogger, partial?: TPartial);
|
|
28
|
+
where: (expr: Expr) => SelectTRB<TTable, TPartial>;
|
|
29
|
+
orderBy<TColumnType extends ColumnType>(callback: (table: TTable) => AbstractColumn<TColumnType, boolean, boolean>, order: Order): SelectTRB<TTable, TPartial>;
|
|
30
|
+
distinct: (column: AbstractColumn<ColumnType<any>, boolean, boolean>) => SelectTRB<TTable, TPartial>;
|
|
31
|
+
limit: (limit: number) => SelectTRB<TTable, TPartial>;
|
|
32
|
+
offset: (offset: number) => SelectTRB<TTable, TPartial>;
|
|
33
|
+
innerJoin<TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(table: {
|
|
34
|
+
new (db: DB): IToTable;
|
|
35
|
+
}, from: (table: TTable) => AbstractColumn<TColumn, boolean, boolean>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean>, partial?: IToPartial): SelectTRBWithJoin<TTable, IToTable, TPartial, IToPartial>;
|
|
36
|
+
leftJoin<TColumn extends ColumnType<any>, IToColumn extends ColumnType<any>, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(table: {
|
|
37
|
+
new (db: DB): IToTable;
|
|
38
|
+
}, from: (table: TTable) => AbstractColumn<TColumn, boolean, boolean, TTable>, to: (table: IToTable) => AbstractColumn<IToColumn, boolean, boolean, IToTable>, partial?: IToPartial): SelectTRBWithJoin<TTable, IToTable, TPartial, IToPartial>;
|
|
39
|
+
rightJoin<TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(table: {
|
|
40
|
+
new (db: DB): IToTable;
|
|
41
|
+
}, from: (table: TTable) => AbstractColumn<TColumn, boolean, boolean>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean>, partial?: IToPartial): SelectTRBWithJoin<TTable, IToTable, TPartial, IToPartial>;
|
|
42
|
+
fullJoin<TColumn extends ColumnType, TToColumn extends ColumnType, IToTable extends AbstractTable<IToTable>, IToPartial extends PartialFor<IToTable> = {}>(table: {
|
|
43
|
+
new (db: DB): IToTable;
|
|
44
|
+
}, from: (table: TTable) => AbstractColumn<TColumn, boolean, boolean>, to: (table: IToTable) => AbstractColumn<TToColumn, boolean, boolean>, partial?: IToPartial): SelectTRBWithJoin<TTable, IToTable, TPartial, IToPartial>;
|
|
45
|
+
execute: () => Promise<([keyof TPartial] extends [never] ? ExtractModel<TTable> : ExtractModel<TPartial>)[]>;
|
|
46
|
+
protected _execute: () => Promise<Array<[keyof TPartial] extends [never] ? ExtractModel<TTable> : ExtractModel<TPartial>>>;
|
|
47
|
+
}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
22
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
|
+
};
|
|
24
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
+
const __1 = require("..");
|
|
26
|
+
const builderError_1 = __importStar(require("../../errors/builderError"));
|
|
27
|
+
const responseMapper_1 = __importDefault(require("../../mappers/responseMapper"));
|
|
28
|
+
const selectWithJoin_1 = __importDefault(require("../joinBuilders/builders/selectWithJoin"));
|
|
29
|
+
const join_1 = require("../joinBuilders/join");
|
|
30
|
+
const abstractRequestBuilder_1 = __importDefault(require("./abstractRequestBuilder"));
|
|
31
|
+
class SelectTRB extends abstractRequestBuilder_1.default {
|
|
32
|
+
constructor(session, mappedServiceToDb, props, table, logger, partial) {
|
|
33
|
+
super(table, session, mappedServiceToDb, logger);
|
|
34
|
+
this.where = (expr) => {
|
|
35
|
+
this._filter = expr;
|
|
36
|
+
return this;
|
|
37
|
+
};
|
|
38
|
+
this.distinct = (column) => {
|
|
39
|
+
this.__distinct = column;
|
|
40
|
+
return this;
|
|
41
|
+
};
|
|
42
|
+
this.limit = (limit) => {
|
|
43
|
+
this.props.limit = limit;
|
|
44
|
+
return this;
|
|
45
|
+
};
|
|
46
|
+
this.offset = (offset) => {
|
|
47
|
+
this.props.offset = offset;
|
|
48
|
+
return this;
|
|
49
|
+
};
|
|
50
|
+
this.execute = async () => {
|
|
51
|
+
const res = await this._execute();
|
|
52
|
+
return res;
|
|
53
|
+
};
|
|
54
|
+
this._execute = async () => {
|
|
55
|
+
// Select.from().filteredBy().limit().offset().orderBy().groupBy().build()
|
|
56
|
+
const queryBuilder = __1.Select
|
|
57
|
+
.from(this._table, this.__partial)
|
|
58
|
+
.distinct(this.__distinct)
|
|
59
|
+
.filteredBy(this._filter)
|
|
60
|
+
.limit(this.props.limit)
|
|
61
|
+
.offset(this.props.offset)
|
|
62
|
+
.orderBy(this.__orderBy, this.__order);
|
|
63
|
+
let query = '';
|
|
64
|
+
let values = [];
|
|
65
|
+
try {
|
|
66
|
+
const builderResult = queryBuilder.build();
|
|
67
|
+
query = builderResult.query;
|
|
68
|
+
values = builderResult.values;
|
|
69
|
+
}
|
|
70
|
+
catch (e) {
|
|
71
|
+
throw new builderError_1.default(builderError_1.BuilderType.SELECT, this._table.tableName(), this._columns, e, this._filter);
|
|
72
|
+
}
|
|
73
|
+
if (this._logger) {
|
|
74
|
+
this._logger.info(`Selecting from ${this._table.tableName()} using query:\n ${query}`);
|
|
75
|
+
}
|
|
76
|
+
const result = await this._session.execute(query, values);
|
|
77
|
+
if (this.__partial) {
|
|
78
|
+
return responseMapper_1.default.partialMap(this.__partial, result);
|
|
79
|
+
}
|
|
80
|
+
return responseMapper_1.default.map(this._mappedServiceToDb, result);
|
|
81
|
+
};
|
|
82
|
+
this.props = props;
|
|
83
|
+
this.__partial = partial;
|
|
84
|
+
}
|
|
85
|
+
orderBy(callback, order) {
|
|
86
|
+
this.__orderBy = callback(this._table);
|
|
87
|
+
this.__order = order;
|
|
88
|
+
return this;
|
|
89
|
+
}
|
|
90
|
+
// public groupBy(callback: (table: TTable) => Column<ColumnType, boolean, boolean>)
|
|
91
|
+
// : SelectTRB<TTable> {
|
|
92
|
+
// this.__groupBy = callback(this.__table);
|
|
93
|
+
// return this;
|
|
94
|
+
// }
|
|
95
|
+
innerJoin(table, from, to, partial) {
|
|
96
|
+
const toTable = this._table.db.create(table);
|
|
97
|
+
const fromColumn = from(this._table);
|
|
98
|
+
const toColumn = to(toTable);
|
|
99
|
+
const join = new __1.JoinWith(toTable.tableName(), toTable.mapServiceToDb())
|
|
100
|
+
.columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.INNER_JOIN);
|
|
101
|
+
return new selectWithJoin_1.default(this._table, this._session, this._filter, join, this.props, this.__orderBy, this.__order, this.__distinct, this.__partial, partial);
|
|
102
|
+
}
|
|
103
|
+
leftJoin(table, from, to, partial) {
|
|
104
|
+
const toTable = this._table.db.create(table);
|
|
105
|
+
const fromColumn = from(this._table);
|
|
106
|
+
const toColumn = to(toTable);
|
|
107
|
+
const join = new __1.JoinWith(toTable.tableName(), toTable.mapServiceToDb())
|
|
108
|
+
.columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.LEFT_JOIN);
|
|
109
|
+
return new selectWithJoin_1.default(this._table, this._session, this._filter, join, this.props, this.__orderBy, this.__order, this.__distinct, this.__partial, partial);
|
|
110
|
+
}
|
|
111
|
+
rightJoin(table, from, to, partial) {
|
|
112
|
+
const toTable = this._table.db.create(table);
|
|
113
|
+
const fromColumn = from(this._table);
|
|
114
|
+
const toColumn = to(toTable);
|
|
115
|
+
const join = new __1.JoinWith(toTable.tableName(), toTable.mapServiceToDb())
|
|
116
|
+
.columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.RIGHT_JOIN);
|
|
117
|
+
return new selectWithJoin_1.default(this._table, this._session, this._filter, join, this.props, this.__orderBy, this.__order, this.__distinct, this.__partial, partial);
|
|
118
|
+
}
|
|
119
|
+
fullJoin(table, from, to, partial) {
|
|
120
|
+
const toTable = this._table.db.create(table);
|
|
121
|
+
const fromColumn = from(this._table);
|
|
122
|
+
const toColumn = to(toTable);
|
|
123
|
+
const join = new __1.JoinWith(toTable.tableName(), toTable.mapServiceToDb())
|
|
124
|
+
.columns(fromColumn, toColumn).joinStrategy(join_1.JoinStrategy.FULL_JOIN);
|
|
125
|
+
return new selectWithJoin_1.default(this._table, this._session, this._filter, join, this.props, this.__orderBy, this.__order, this.__distinct, this.__partial, partial);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
exports.default = SelectTRB;
|