drizzle-orm 0.11.4 → 0.12.0-beta.0
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/branded-types.d.ts +18 -0
- package/branded-types.js +6 -0
- package/branded-types.js.map +1 -0
- package/column-builder.d.ts +14 -0
- package/column-builder.js +24 -0
- package/column-builder.js.map +1 -0
- package/column.d.ts +37 -0
- package/column.js +41 -0
- package/column.js.map +1 -0
- package/connection.d.ts +29 -0
- package/connection.js +91 -0
- package/connection.js.map +1 -0
- package/expressions.d.ts +1 -0
- package/expressions.js +18 -0
- package/expressions.js.map +1 -0
- package/index.d.ts +4 -13
- package/index.js +11 -24
- package/index.js.map +1 -1
- package/operations.d.ts +13 -0
- package/{tables/inferTypes.js → operations.js} +1 -1
- package/operations.js.map +1 -0
- package/package.json +57 -30
- package/sql/expressions/conditions.d.ts +33 -0
- package/sql/expressions/conditions.js +140 -0
- package/sql/expressions/conditions.js.map +1 -0
- package/sql/expressions/index.d.ts +2 -0
- package/sql/expressions/index.js +19 -0
- package/sql/expressions/index.js.map +1 -0
- package/sql/expressions/select.d.ts +5 -0
- package/sql/expressions/select.js +13 -0
- package/sql/expressions/select.js.map +1 -0
- package/sql/index.d.ts +97 -0
- package/sql/index.js +172 -0
- package/sql/index.js.map +1 -0
- package/table.d.ts +10 -0
- package/table.js +36 -0
- package/table.js.map +1 -0
- package/utils.d.ts +7 -0
- package/utils.js +18 -0
- package/utils.js.map +1 -0
- package/LICENSE +0 -674
- package/README.md +0 -343
- package/builders/aggregators/abstractAggregator.d.ts +0 -12
- package/builders/aggregators/abstractAggregator.js +0 -52
- package/builders/aggregators/abstractAggregator.js.map +0 -1
- package/builders/aggregators/deleteAggregator.d.ts +0 -16
- package/builders/aggregators/deleteAggregator.js +0 -43
- package/builders/aggregators/deleteAggregator.js.map +0 -1
- package/builders/aggregators/insertAggregator.d.ts +0 -22
- package/builders/aggregators/insertAggregator.js +0 -110
- package/builders/aggregators/insertAggregator.js.map +0 -1
- package/builders/aggregators/selectAggregator.d.ts +0 -33
- package/builders/aggregators/selectAggregator.js +0 -111
- package/builders/aggregators/selectAggregator.js.map +0 -1
- package/builders/aggregators/selectAggregatorV1.d.ts +0 -39
- package/builders/aggregators/selectAggregatorV1.js +0 -144
- package/builders/aggregators/selectAggregatorV1.js.map +0 -1
- package/builders/aggregators/updateAggregator.d.ts +0 -19
- package/builders/aggregators/updateAggregator.js +0 -54
- package/builders/aggregators/updateAggregator.js.map +0 -1
- package/builders/highLvlBuilders/abstractRequestBuilder.d.ts +0 -27
- package/builders/highLvlBuilders/abstractRequestBuilder.js +0 -34
- package/builders/highLvlBuilders/abstractRequestBuilder.js.map +0 -1
- package/builders/highLvlBuilders/deleteRequestBuilder.d.ts +0 -19
- package/builders/highLvlBuilders/deleteRequestBuilder.js +0 -62
- package/builders/highLvlBuilders/deleteRequestBuilder.js.map +0 -1
- package/builders/highLvlBuilders/insertRequestBuilder.d.ts +0 -20
- package/builders/highLvlBuilders/insertRequestBuilder.js +0 -74
- package/builders/highLvlBuilders/insertRequestBuilder.js.map +0 -1
- package/builders/highLvlBuilders/joins/joinBuilderResponse.d.ts +0 -8
- package/builders/highLvlBuilders/joins/joinBuilderResponse.js +0 -17
- package/builders/highLvlBuilders/joins/joinBuilderResponse.js.map +0 -1
- package/builders/highLvlBuilders/joins/proxies/joinProxies.d.ts +0 -16
- package/builders/highLvlBuilders/joins/proxies/joinProxies.js +0 -48
- package/builders/highLvlBuilders/joins/proxies/joinProxies.js.map +0 -1
- package/builders/highLvlBuilders/joins/selectJoinBuilder.d.ts +0 -44
- package/builders/highLvlBuilders/joins/selectJoinBuilder.js +0 -114
- package/builders/highLvlBuilders/joins/selectJoinBuilder.js.map +0 -1
- package/builders/highLvlBuilders/order.d.ts +0 -5
- package/builders/highLvlBuilders/order.js +0 -9
- package/builders/highLvlBuilders/order.js.map +0 -1
- package/builders/highLvlBuilders/selectRequestBuilder.d.ts +0 -63
- package/builders/highLvlBuilders/selectRequestBuilder.js +0 -171
- package/builders/highLvlBuilders/selectRequestBuilder.js.map +0 -1
- package/builders/highLvlBuilders/updateRequestBuilder.d.ts +0 -22
- package/builders/highLvlBuilders/updateRequestBuilder.js +0 -81
- package/builders/highLvlBuilders/updateRequestBuilder.js.map +0 -1
- package/builders/index.d.ts +0 -21
- package/builders/index.js +0 -69
- package/builders/index.js.map +0 -1
- package/builders/joinBuilders/builders/abstractJoinBuilder.d.ts +0 -42
- package/builders/joinBuilders/builders/abstractJoinBuilder.js +0 -82
- package/builders/joinBuilders/builders/abstractJoinBuilder.js.map +0 -1
- package/builders/joinBuilders/builders/selectWithFiveJoins.d.ts +0 -36
- package/builders/joinBuilders/builders/selectWithFiveJoins.js +0 -46
- package/builders/joinBuilders/builders/selectWithFiveJoins.js.map +0 -1
- package/builders/joinBuilders/builders/selectWithFourJoins.d.ts +0 -56
- package/builders/joinBuilders/builders/selectWithFourJoins.js +0 -79
- package/builders/joinBuilders/builders/selectWithFourJoins.js.map +0 -1
- package/builders/joinBuilders/builders/selectWithJoin.d.ts +0 -50
- package/builders/joinBuilders/builders/selectWithJoin.js +0 -65
- package/builders/joinBuilders/builders/selectWithJoin.js.map +0 -1
- package/builders/joinBuilders/builders/selectWithThreeJoins.d.ts +0 -54
- package/builders/joinBuilders/builders/selectWithThreeJoins.js +0 -74
- package/builders/joinBuilders/builders/selectWithThreeJoins.js.map +0 -1
- package/builders/joinBuilders/builders/selectWithTwoJoins.d.ts +0 -52
- package/builders/joinBuilders/builders/selectWithTwoJoins.js +0 -72
- package/builders/joinBuilders/builders/selectWithTwoJoins.js.map +0 -1
- package/builders/joinBuilders/join.d.ts +0 -23
- package/builders/joinBuilders/join.js +0 -29
- package/builders/joinBuilders/join.js.map +0 -1
- package/builders/joinBuilders/joinWith.d.ts +0 -14
- package/builders/joinBuilders/joinWith.js +0 -15
- package/builders/joinBuilders/joinWith.js.map +0 -1
- package/builders/joinBuilders/responses/selectResponseFiveJoins.d.ts +0 -20
- package/builders/joinBuilders/responses/selectResponseFiveJoins.js +0 -36
- package/builders/joinBuilders/responses/selectResponseFiveJoins.js.map +0 -1
- package/builders/joinBuilders/responses/selectResponseFourJoins.d.ts +0 -19
- package/builders/joinBuilders/responses/selectResponseFourJoins.js +0 -35
- package/builders/joinBuilders/responses/selectResponseFourJoins.js.map +0 -1
- package/builders/joinBuilders/responses/selectResponseThreeJoins.d.ts +0 -18
- package/builders/joinBuilders/responses/selectResponseThreeJoins.js +0 -34
- package/builders/joinBuilders/responses/selectResponseThreeJoins.js.map +0 -1
- package/builders/joinBuilders/responses/selectResponseTwoJoins.d.ts +0 -17
- package/builders/joinBuilders/responses/selectResponseTwoJoins.js +0 -33
- package/builders/joinBuilders/responses/selectResponseTwoJoins.js.map +0 -1
- package/builders/joinBuilders/responses/selectResponseWithJoin.d.ts +0 -16
- package/builders/joinBuilders/responses/selectResponseWithJoin.js +0 -32
- package/builders/joinBuilders/responses/selectResponseWithJoin.js.map +0 -1
- package/builders/joinBuilders/static.d.ts +0 -5
- package/builders/joinBuilders/static.js +0 -10
- package/builders/joinBuilders/static.js.map +0 -1
- package/builders/lowLvlBuilders/alter.d.ts +0 -0
- package/builders/lowLvlBuilders/alter.js +0 -2
- package/builders/lowLvlBuilders/alter.js.map +0 -1
- package/builders/lowLvlBuilders/create.d.ts +0 -12
- package/builders/lowLvlBuilders/create.js +0 -101
- package/builders/lowLvlBuilders/create.js.map +0 -1
- package/builders/lowLvlBuilders/delets/delete.d.ts +0 -5
- package/builders/lowLvlBuilders/delets/delete.js +0 -16
- package/builders/lowLvlBuilders/delets/delete.js.map +0 -1
- package/builders/lowLvlBuilders/delets/deleteFilter.d.ts +0 -11
- package/builders/lowLvlBuilders/delets/deleteFilter.js +0 -14
- package/builders/lowLvlBuilders/delets/deleteFilter.js.map +0 -1
- package/builders/lowLvlBuilders/delets/deleteFrom.d.ts +0 -12
- package/builders/lowLvlBuilders/delets/deleteFrom.js +0 -15
- package/builders/lowLvlBuilders/delets/deleteFrom.js.map +0 -1
- package/builders/lowLvlBuilders/inserts/insert.d.ts +0 -5
- package/builders/lowLvlBuilders/inserts/insert.js +0 -16
- package/builders/lowLvlBuilders/inserts/insert.js.map +0 -1
- package/builders/lowLvlBuilders/inserts/insertInto.d.ts +0 -13
- package/builders/lowLvlBuilders/inserts/insertInto.js +0 -17
- package/builders/lowLvlBuilders/inserts/insertInto.js.map +0 -1
- package/builders/lowLvlBuilders/inserts/onConflictInsert.d.ts +0 -12
- package/builders/lowLvlBuilders/inserts/onConflictInsert.js +0 -14
- package/builders/lowLvlBuilders/inserts/onConflictInsert.js.map +0 -1
- package/builders/lowLvlBuilders/inserts/valuesInsert.d.ts +0 -16
- package/builders/lowLvlBuilders/inserts/valuesInsert.js +0 -20
- package/builders/lowLvlBuilders/inserts/valuesInsert.js.map +0 -1
- package/builders/lowLvlBuilders/selects/select.d.ts +0 -12
- package/builders/lowLvlBuilders/selects/select.js +0 -43
- package/builders/lowLvlBuilders/selects/select.js.map +0 -1
- package/builders/lowLvlBuilders/selects/selectFrom.d.ts +0 -45
- package/builders/lowLvlBuilders/selects/selectFrom.js +0 -79
- package/builders/lowLvlBuilders/selects/selectFrom.js.map +0 -1
- package/builders/lowLvlBuilders/selects/selectJoined.d.ts +0 -42
- package/builders/lowLvlBuilders/selects/selectJoined.js +0 -72
- package/builders/lowLvlBuilders/selects/selectJoined.js.map +0 -1
- package/builders/lowLvlBuilders/selects/whereSelect.d.ts +0 -30
- package/builders/lowLvlBuilders/selects/whereSelect.js +0 -50
- package/builders/lowLvlBuilders/selects/whereSelect.js.map +0 -1
- package/builders/lowLvlBuilders/updates/update.d.ts +0 -5
- package/builders/lowLvlBuilders/updates/update.js +0 -16
- package/builders/lowLvlBuilders/updates/update.js.map +0 -1
- package/builders/lowLvlBuilders/updates/updateIn.d.ts +0 -13
- package/builders/lowLvlBuilders/updates/updateIn.js +0 -16
- package/builders/lowLvlBuilders/updates/updateIn.js.map +0 -1
- package/builders/lowLvlBuilders/updates/whereSelect.d.ts +0 -11
- package/builders/lowLvlBuilders/updates/whereSelect.js +0 -14
- package/builders/lowLvlBuilders/updates/whereSelect.js.map +0 -1
- package/builders/lowLvlBuilders/updates/whereSet.d.ts +0 -14
- package/builders/lowLvlBuilders/updates/whereSet.js +0 -19
- package/builders/lowLvlBuilders/updates/whereSet.js.map +0 -1
- package/builders/requestBuilders/updates/combine.d.ts +0 -13
- package/builders/requestBuilders/updates/combine.js +0 -27
- package/builders/requestBuilders/updates/combine.js.map +0 -1
- package/builders/requestBuilders/updates/increment.d.ts +0 -17
- package/builders/requestBuilders/updates/increment.js +0 -19
- package/builders/requestBuilders/updates/increment.js.map +0 -1
- package/builders/requestBuilders/updates/setObjects.d.ts +0 -16
- package/builders/requestBuilders/updates/setObjects.js +0 -20
- package/builders/requestBuilders/updates/setObjects.js.map +0 -1
- package/builders/requestBuilders/updates/static.d.ts +0 -7
- package/builders/requestBuilders/updates/static.js +0 -16
- package/builders/requestBuilders/updates/static.js.map +0 -1
- package/builders/requestBuilders/updates/updates.d.ts +0 -13
- package/builders/requestBuilders/updates/updates.js +0 -10
- package/builders/requestBuilders/updates/updates.js.map +0 -1
- package/builders/requestBuilders/where/and.d.ts +0 -23
- package/builders/requestBuilders/where/and.js +0 -49
- package/builders/requestBuilders/where/and.js.map +0 -1
- package/builders/requestBuilders/where/const.d.ts +0 -20
- package/builders/requestBuilders/where/const.js +0 -35
- package/builders/requestBuilders/where/const.js.map +0 -1
- package/builders/requestBuilders/where/constArray.d.ts +0 -20
- package/builders/requestBuilders/where/constArray.js +0 -65
- package/builders/requestBuilders/where/constArray.js.map +0 -1
- package/builders/requestBuilders/where/eqWhere.d.ts +0 -27
- package/builders/requestBuilders/where/eqWhere.js +0 -26
- package/builders/requestBuilders/where/eqWhere.js.map +0 -1
- package/builders/requestBuilders/where/greater.d.ts +0 -27
- package/builders/requestBuilders/where/greater.js +0 -26
- package/builders/requestBuilders/where/greater.js.map +0 -1
- package/builders/requestBuilders/where/greaterEq.d.ts +0 -27
- package/builders/requestBuilders/where/greaterEq.js +0 -26
- package/builders/requestBuilders/where/greaterEq.js.map +0 -1
- package/builders/requestBuilders/where/in.d.ts +0 -24
- package/builders/requestBuilders/where/in.js +0 -26
- package/builders/requestBuilders/where/in.js.map +0 -1
- package/builders/requestBuilders/where/isNotNull.d.ts +0 -23
- package/builders/requestBuilders/where/isNotNull.js +0 -23
- package/builders/requestBuilders/where/isNotNull.js.map +0 -1
- package/builders/requestBuilders/where/isNull.d.ts +0 -23
- package/builders/requestBuilders/where/isNull.js +0 -23
- package/builders/requestBuilders/where/isNull.js.map +0 -1
- package/builders/requestBuilders/where/less.d.ts +0 -27
- package/builders/requestBuilders/where/less.js +0 -26
- package/builders/requestBuilders/where/less.js.map +0 -1
- package/builders/requestBuilders/where/lessEq.d.ts +0 -27
- package/builders/requestBuilders/where/lessEq.js +0 -26
- package/builders/requestBuilders/where/lessEq.js.map +0 -1
- package/builders/requestBuilders/where/like.d.ts +0 -24
- package/builders/requestBuilders/where/like.js +0 -26
- package/builders/requestBuilders/where/like.js.map +0 -1
- package/builders/requestBuilders/where/notEqWhere.d.ts +0 -24
- package/builders/requestBuilders/where/notEqWhere.js +0 -26
- package/builders/requestBuilders/where/notEqWhere.js.map +0 -1
- package/builders/requestBuilders/where/or.d.ts +0 -23
- package/builders/requestBuilders/where/or.js +0 -49
- package/builders/requestBuilders/where/or.js.map +0 -1
- package/builders/requestBuilders/where/rawWhere.d.ts +0 -23
- package/builders/requestBuilders/where/rawWhere.js +0 -17
- package/builders/requestBuilders/where/rawWhere.js.map +0 -1
- package/builders/requestBuilders/where/static.d.ts +0 -21
- package/builders/requestBuilders/where/static.js +0 -57
- package/builders/requestBuilders/where/static.js.map +0 -1
- package/builders/requestBuilders/where/static.spec.d.ts +0 -1
- package/builders/requestBuilders/where/static.spec.js +0 -60
- package/builders/requestBuilders/where/static.spec.js.map +0 -1
- package/builders/requestBuilders/where/var.d.ts +0 -25
- package/builders/requestBuilders/where/var.js +0 -23
- package/builders/requestBuilders/where/var.js.map +0 -1
- package/builders/requestBuilders/where/where.d.ts +0 -20
- package/builders/requestBuilders/where/where.js +0 -6
- package/builders/requestBuilders/where/where.js.map +0 -1
- package/builders/transaction/transaction.d.ts +0 -8
- package/builders/transaction/transaction.js +0 -21
- package/builders/transaction/transaction.js.map +0 -1
- package/columns/column.d.ts +0 -81
- package/columns/column.js +0 -119
- package/columns/column.js.map +0 -1
- package/columns/index.d.ts +0 -10
- package/columns/index.js +0 -30
- package/columns/index.js.map +0 -1
- package/columns/types/columnType.d.ts +0 -7
- package/columns/types/columnType.js +0 -7
- package/columns/types/columnType.js.map +0 -1
- package/columns/types/pgBigDecimal.d.ts +0 -10
- package/columns/types/pgBigDecimal.js +0 -32
- package/columns/types/pgBigDecimal.js.map +0 -1
- package/columns/types/pgBigInt.d.ts +0 -15
- package/columns/types/pgBigInt.js +0 -33
- package/columns/types/pgBigInt.js.map +0 -1
- package/columns/types/pgBigSerial.d.ts +0 -15
- package/columns/types/pgBigSerial.js +0 -33
- package/columns/types/pgBigSerial.js.map +0 -1
- package/columns/types/pgBoolean.d.ts +0 -8
- package/columns/types/pgBoolean.js +0 -19
- package/columns/types/pgBoolean.js.map +0 -1
- package/columns/types/pgEnum.d.ts +0 -9
- package/columns/types/pgEnum.js +0 -19
- package/columns/types/pgEnum.js.map +0 -1
- package/columns/types/pgInteger.d.ts +0 -8
- package/columns/types/pgInteger.js +0 -22
- package/columns/types/pgInteger.js.map +0 -1
- package/columns/types/pgJsonb.d.ts +0 -9
- package/columns/types/pgJsonb.js +0 -21
- package/columns/types/pgJsonb.js.map +0 -1
- package/columns/types/pgSerial.d.ts +0 -8
- package/columns/types/pgSerial.js +0 -19
- package/columns/types/pgSerial.js.map +0 -1
- package/columns/types/pgSmallInt.d.ts +0 -8
- package/columns/types/pgSmallInt.js +0 -19
- package/columns/types/pgSmallInt.js.map +0 -1
- package/columns/types/pgText.d.ts +0 -8
- package/columns/types/pgText.js +0 -19
- package/columns/types/pgText.js.map +0 -1
- package/columns/types/pgTime.d.ts +0 -8
- package/columns/types/pgTime.js +0 -19
- package/columns/types/pgTime.js.map +0 -1
- package/columns/types/pgTimestamp.d.ts +0 -8
- package/columns/types/pgTimestamp.js +0 -19
- package/columns/types/pgTimestamp.js.map +0 -1
- package/columns/types/pgTimestamptz.d.ts +0 -8
- package/columns/types/pgTimestamptz.js +0 -19
- package/columns/types/pgTimestamptz.js.map +0 -1
- package/columns/types/pgVarChar.d.ts +0 -9
- package/columns/types/pgVarChar.js +0 -25
- package/columns/types/pgVarChar.js.map +0 -1
- package/db/db.d.ts +0 -18
- package/db/db.js +0 -26
- package/db/db.js.map +0 -1
- package/db/dbConnector.d.ts +0 -9
- package/db/dbConnector.js +0 -33
- package/db/dbConnector.js.map +0 -1
- package/db/dbStringConnector.d.ts +0 -6
- package/db/dbStringConnector.js +0 -30
- package/db/dbStringConnector.js.map +0 -1
- package/db/group_by.d.ts +0 -0
- package/db/group_by.js +0 -69
- package/db/group_by.js.map +0 -1
- package/db/index.d.ts +0 -4
- package/db/index.js +0 -15
- package/db/index.js.map +0 -1
- package/db/session.d.ts +0 -16
- package/db/session.js +0 -40
- package/db/session.js.map +0 -1
- package/docs/cases/simple_delete.d.ts +0 -1
- package/docs/cases/simple_delete.js +0 -36
- package/docs/cases/simple_delete.js.map +0 -1
- package/docs/cases/simple_insert.d.ts +0 -1
- package/docs/cases/simple_insert.js +0 -58
- package/docs/cases/simple_insert.js.map +0 -1
- package/docs/cases/simple_join.d.ts +0 -1
- package/docs/cases/simple_join.js +0 -116
- package/docs/cases/simple_join.js.map +0 -1
- package/docs/cases/simple_select.d.ts +0 -1
- package/docs/cases/simple_select.js +0 -51
- package/docs/cases/simple_select.js.map +0 -1
- package/docs/cases/simple_update.d.ts +0 -1
- package/docs/cases/simple_update.js +0 -40
- package/docs/cases/simple_update.js.map +0 -1
- package/docs/tables/citiesTable.d.ts +0 -14
- package/docs/tables/citiesTable.js +0 -22
- package/docs/tables/citiesTable.js.map +0 -1
- package/docs/tables/userGroupsTable.d.ts +0 -8
- package/docs/tables/userGroupsTable.js +0 -20
- package/docs/tables/userGroupsTable.js.map +0 -1
- package/docs/tables/usersTable.d.ts +0 -17
- package/docs/tables/usersTable.js +0 -36
- package/docs/tables/usersTable.js.map +0 -1
- package/docs/tables/usersToUserGroups.d.ts +0 -7
- package/docs/tables/usersToUserGroups.js +0 -21
- package/docs/tables/usersToUserGroups.js.map +0 -1
- package/docs/types/rolesType.d.ts +0 -1
- package/docs/types/rolesType.js +0 -7
- package/docs/types/rolesType.js.map +0 -1
- package/errors/baseError.d.ts +0 -22
- package/errors/baseError.js +0 -36
- package/errors/baseError.js.map +0 -1
- package/errors/builderError.d.ts +0 -15
- package/errors/builderError.js +0 -26
- package/errors/builderError.js.map +0 -1
- package/errors/dbErrors.d.ts +0 -12
- package/errors/dbErrors.js +0 -29
- package/errors/dbErrors.js.map +0 -1
- package/indexes/tableIndex.d.ts +0 -11
- package/indexes/tableIndex.js +0 -18
- package/indexes/tableIndex.js.map +0 -1
- package/logger/abstractLogger.d.ts +0 -4
- package/logger/abstractLogger.js +0 -6
- package/logger/abstractLogger.js.map +0 -1
- package/logger/consoleLogger.d.ts +0 -5
- package/logger/consoleLogger.js +0 -16
- package/logger/consoleLogger.js.map +0 -1
- package/mappers/index.d.ts +0 -0
- package/mappers/index.js +0 -2
- package/mappers/index.js.map +0 -1
- package/mappers/responseMapper.d.ts +0 -15
- package/mappers/responseMapper.js +0 -69
- package/mappers/responseMapper.js.map +0 -1
- package/migrator/index.d.ts +0 -0
- package/migrator/index.js +0 -2
- package/migrator/index.js.map +0 -1
- package/migrator/migrator.d.ts +0 -11
- package/migrator/migrator.js +0 -113
- package/migrator/migrator.js.map +0 -1
- package/serializer/serializer.d.ts +0 -58
- package/serializer/serializer.js +0 -260
- package/serializer/serializer.js.map +0 -1
- package/tables/abstractTable.d.ts +0 -69
- package/tables/abstractTable.js +0 -158
- package/tables/abstractTable.js.map +0 -1
- package/tables/index.d.ts +0 -3
- package/tables/index.js +0 -12
- package/tables/index.js.map +0 -1
- package/tables/inferTypes.d.ts +0 -48
- package/tables/inferTypes.js.map +0 -1
- package/tables/migrationsTable.d.ts +0 -7
- package/tables/migrationsTable.js +0 -19
- package/tables/migrationsTable.js.map +0 -1
- package/types/type.d.ts +0 -10
- package/types/type.js +0 -15
- package/types/type.js.map +0 -1
- package/utils/ecranate.d.ts +0 -2
- package/utils/ecranate.js +0 -9
- package/utils/ecranate.js.map +0 -1
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export declare const brand: unique symbol;
|
|
2
|
+
export declare const value: unique symbol;
|
|
3
|
+
export declare type Brand<T, TName extends string> = T & {
|
|
4
|
+
[brand]: TName;
|
|
5
|
+
[value]: T;
|
|
6
|
+
};
|
|
7
|
+
export declare type AnyBrand = {
|
|
8
|
+
[brand]: any;
|
|
9
|
+
[value]: any;
|
|
10
|
+
};
|
|
11
|
+
export declare type Unwrap<T extends AnyBrand> = T extends {
|
|
12
|
+
[value]: infer TValue;
|
|
13
|
+
} ? TValue : never;
|
|
14
|
+
export declare type TableName<T extends string = string> = Brand<T, 'TableName'>;
|
|
15
|
+
export declare type ColumnData<T = unknown> = Brand<T, 'ColumnData'>;
|
|
16
|
+
export declare type ColumnDriverParam<T = unknown> = Brand<T, 'ColumnDriverParam'>;
|
|
17
|
+
export declare type ColumnNotNull<T extends boolean = boolean> = Brand<T, 'ColumnNotNull'>;
|
|
18
|
+
export declare type ColumnHasDefault<T extends boolean = boolean> = Brand<T, 'ColumnHasDefault'>;
|
package/branded-types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"branded-types.js","sourceRoot":"","sources":["../src/branded-types.ts"],"names":[],"mappings":";;;AAAa,QAAA,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;AACxB,QAAA,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { ColumnData, ColumnDriverParam, ColumnHasDefault, ColumnNotNull, Unwrap } from './branded-types';
|
|
2
|
+
import { AnySQL } from './sql';
|
|
3
|
+
export declare abstract class ColumnBuilder<TData extends ColumnData, TDriverParam extends ColumnDriverParam, TNotNull extends ColumnNotNull<boolean>, THasDefault extends ColumnHasDefault<boolean>> {
|
|
4
|
+
protected typeKeeper: {
|
|
5
|
+
brand: 'ColumnBuilder';
|
|
6
|
+
dataType: TData;
|
|
7
|
+
notNull: TNotNull;
|
|
8
|
+
default: THasDefault;
|
|
9
|
+
};
|
|
10
|
+
constructor(name: string);
|
|
11
|
+
notNull(): ColumnBuilder<TData, TDriverParam, ColumnNotNull<true>, THasDefault>;
|
|
12
|
+
default(value: Unwrap<TData> | AnySQL): ColumnBuilder<TData, TDriverParam, TNotNull, ColumnHasDefault<true>>;
|
|
13
|
+
primaryKey(): ColumnBuilder<TData, TDriverParam, ColumnNotNull<true>, THasDefault>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ColumnBuilder = void 0;
|
|
4
|
+
class ColumnBuilder {
|
|
5
|
+
constructor(name) {
|
|
6
|
+
/** @internal */ this._notNull = false;
|
|
7
|
+
/** @internal */ this._primaryKey = false;
|
|
8
|
+
this.name = name;
|
|
9
|
+
}
|
|
10
|
+
notNull() {
|
|
11
|
+
this._notNull = true;
|
|
12
|
+
return this;
|
|
13
|
+
}
|
|
14
|
+
default(value) {
|
|
15
|
+
this._default = value;
|
|
16
|
+
return this;
|
|
17
|
+
}
|
|
18
|
+
primaryKey() {
|
|
19
|
+
this._primaryKey = true;
|
|
20
|
+
return this;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.ColumnBuilder = ColumnBuilder;
|
|
24
|
+
//# sourceMappingURL=column-builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"column-builder.js","sourceRoot":"","sources":["../src/column-builder.ts"],"names":[],"mappings":";;;AAKA,MAAsB,aAAa;IAmBlC,YAAY,IAAY;QANxB,gBAAgB,CAAC,aAAQ,GAAG,KAAiB,CAAC;QAG9C,gBAAgB,CAAC,gBAAW,GAAG,KAAK,CAAC;QAIpC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IAClB,CAAC;IAED,OAAO;QACN,IAAI,CAAC,QAAQ,GAAG,IAAgB,CAAC;QACjC,OAAO,IAAW,CAAC;IACpB,CAAC;IAED,OAAO,CACN,KAA6B;QAE7B,IAAI,CAAC,QAAQ,GAAG,KAAc,CAAC;QAC/B,OAAO,IAAW,CAAC;IACpB,CAAC;IAED,UAAU;QACT,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,OAAO,IAAW,CAAC;IACpB,CAAC;CAMD;AA5CD,sCA4CC"}
|
package/column.d.ts
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { ColumnData, ColumnDriverParam, ColumnHasDefault, ColumnNotNull, TableName, Unwrap } from './branded-types';
|
|
2
|
+
import { ColumnBuilder } from './column-builder';
|
|
3
|
+
import { BoundParamValue, ParamValueMapper } from './sql';
|
|
4
|
+
import { AnyTable } from './table';
|
|
5
|
+
export declare abstract class Column<TTableName extends TableName<string>, TData extends ColumnData, TDriverParam extends ColumnDriverParam, TNotNull extends ColumnNotNull<boolean>, THasDefault extends ColumnHasDefault<boolean>> implements ParamValueMapper<any, any> {
|
|
6
|
+
readonly table: AnyTable<TTableName>;
|
|
7
|
+
protected typeKeeper: {
|
|
8
|
+
brand: 'Column';
|
|
9
|
+
tableName: TTableName;
|
|
10
|
+
type: TData;
|
|
11
|
+
driverType: TDriverParam;
|
|
12
|
+
notNull: TNotNull;
|
|
13
|
+
default: THasDefault;
|
|
14
|
+
};
|
|
15
|
+
readonly name: string;
|
|
16
|
+
readonly primary: boolean;
|
|
17
|
+
readonly notNull: TNotNull;
|
|
18
|
+
readonly default: TData | undefined;
|
|
19
|
+
constructor(table: AnyTable<TTableName>, builder: ColumnBuilder<TData, TDriverParam, TNotNull, THasDefault>);
|
|
20
|
+
mapFromDriverValue: (value: any) => any;
|
|
21
|
+
mapToDriverValue: (value: any) => any;
|
|
22
|
+
abstract getSQLType(): string;
|
|
23
|
+
}
|
|
24
|
+
export declare abstract class ColumnWithMapper<TTableName extends TableName<string>, TData extends ColumnData, TDriverParam extends ColumnDriverParam, TNotNull extends ColumnNotNull<boolean>, THasDefault extends ColumnHasDefault<boolean>> extends Column<TTableName, TData, TDriverParam, TNotNull, THasDefault> implements ParamValueMapper<TData, TDriverParam> {
|
|
25
|
+
mapFromDriverValue: (value: Unwrap<TDriverParam>) => Unwrap<TData>;
|
|
26
|
+
mapToDriverValue: (value: Unwrap<TData>) => Unwrap<TDriverParam>;
|
|
27
|
+
}
|
|
28
|
+
export declare type AnyColumn<TTableName extends TableName = TableName, TData extends ColumnData = any, TDriverParam extends ColumnDriverParam = any, TNotNull extends ColumnNotNull = ColumnNotNull, THasDefault extends ColumnHasDefault = ColumnHasDefault> = Column<TTableName, TData, TDriverParam, TNotNull, THasDefault>;
|
|
29
|
+
export declare type AnyColumnWithMapper<TTableName extends TableName = TableName, TData extends ColumnData = any, TDriverParam extends ColumnDriverParam = any, TNotNull extends ColumnNotNull = ColumnNotNull, THasDefault extends ColumnHasDefault = ColumnHasDefault> = ColumnWithMapper<TTableName, TData, TDriverParam, TNotNull, THasDefault>;
|
|
30
|
+
export declare function param<TDataType extends ColumnData, TDriverType extends ColumnDriverParam>(column: AnyColumn<any, TDataType, TDriverType>, value: Unwrap<TDataType>): BoundParamValue<TDataType, TDriverType>;
|
|
31
|
+
export declare type GetColumnData<TColumn, TInferMode extends 'query' | 'raw' = 'query'> = TColumn extends Column<any, infer TData, any, infer TNotNull, any> ? TInferMode extends 'raw' ? Unwrap<TData> : TNotNull extends true ? Unwrap<TData> : Unwrap<TData> | null : never;
|
|
32
|
+
export declare type InferColumnDriverParam<TColumn extends AnyColumn> = TColumn extends Column<TableName, ColumnData, infer TDriverType, ColumnNotNull, ColumnHasDefault> ? Unwrap<TDriverType> : never;
|
|
33
|
+
export declare type InferColumnsDataTypes<TColumns extends Record<string, AnyColumn>> = {
|
|
34
|
+
[Key in keyof TColumns]: GetColumnData<TColumns[Key], 'query'>;
|
|
35
|
+
};
|
|
36
|
+
export declare type InferColumnTable<T extends AnyColumn> = T extends AnyColumn<infer TTable> ? TTable : never;
|
|
37
|
+
export declare type ChangeColumnTable<TColumn extends AnyColumn, TTableName extends TableName> = TColumn extends Column<any, infer TType, infer TDriverType, infer TNotNull, infer THasDefault> ? ColumnWithMapper<TTableName, TType, TDriverType, TNotNull, THasDefault> : never;
|
package/column.js
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.param = exports.ColumnWithMapper = exports.Column = void 0;
|
|
4
|
+
const sql_1 = require("./sql");
|
|
5
|
+
class Column {
|
|
6
|
+
constructor(table, builder) {
|
|
7
|
+
this.table = table;
|
|
8
|
+
/*
|
|
9
|
+
mapFromDriverValue and mapToDriverValue are provided just as a runtime fallback - if you need to override them,
|
|
10
|
+
extend the ColumnWithMapper class instead for proper type-checking.
|
|
11
|
+
*/
|
|
12
|
+
this.mapFromDriverValue = (value) => {
|
|
13
|
+
return value;
|
|
14
|
+
};
|
|
15
|
+
this.mapToDriverValue = (value) => {
|
|
16
|
+
return value;
|
|
17
|
+
};
|
|
18
|
+
this.name = builder.name;
|
|
19
|
+
this.notNull = builder._notNull;
|
|
20
|
+
this.default = builder._default;
|
|
21
|
+
this.primary = builder._primaryKey;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
exports.Column = Column;
|
|
25
|
+
class ColumnWithMapper extends Column {
|
|
26
|
+
constructor() {
|
|
27
|
+
super(...arguments);
|
|
28
|
+
this.mapFromDriverValue = (value) => {
|
|
29
|
+
return value;
|
|
30
|
+
};
|
|
31
|
+
this.mapToDriverValue = (value) => {
|
|
32
|
+
return value;
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
exports.ColumnWithMapper = ColumnWithMapper;
|
|
37
|
+
function param(column, value) {
|
|
38
|
+
return new sql_1.BoundParamValue(value, column);
|
|
39
|
+
}
|
|
40
|
+
exports.param = param;
|
|
41
|
+
//# sourceMappingURL=column.js.map
|
package/column.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"column.js","sourceRoot":"","sources":["../src/column.ts"],"names":[],"mappings":";;;AAEA,+BAA0D;AAG1D,MAAsB,MAAM;IAqB3B,YACU,KAA2B,EACpC,OAAkE;QADzD,UAAK,GAAL,KAAK,CAAsB;QASrC;;;UAGE;QACF,uBAAkB,GAAG,CAAC,KAAU,EAAO,EAAE;YACxC,OAAO,KAAK,CAAC;QACd,CAAC,CAAC;QAEF,qBAAgB,GAAG,CAAC,KAAU,EAAO,EAAE;YACtC,OAAO,KAAK,CAAC;QACd,CAAC,CAAC;QAhBD,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,QAAQ,CAAC;QAChC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,QAAQ,CAAC;QAChC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC;IACpC,CAAC;CAeD;AA5CD,wBA4CC;AAED,MAAsB,gBAMpB,SAAQ,MAA8D;IANxE;;QASU,uBAAkB,GAAG,CAAC,KAA2B,EAAiB,EAAE;YAC5E,OAAO,KAAY,CAAC;QACrB,CAAC,CAAC;QAEO,qBAAgB,GAAG,CAAC,KAAoB,EAAwB,EAAE;YAC1E,OAAO,KAAY,CAAC;QACrB,CAAC,CAAC;IACH,CAAC;CAAA;AAhBD,4CAgBC;AAkBD,SAAgB,KAAK,CACpB,MAA8C,EAC9C,KAAwB;IAExB,OAAO,IAAI,qBAAe,CAAC,KAAkB,EAAE,MAAM,CAAC,CAAC;AACxD,CAAC;AALD,sBAKC"}
|
package/connection.d.ts
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export declare type MigrationMeta = {
|
|
2
|
+
sql: string;
|
|
3
|
+
folderMillis: number;
|
|
4
|
+
hash: string;
|
|
5
|
+
};
|
|
6
|
+
export interface Session<TQueryParam, TQueryResponse> {
|
|
7
|
+
query(query: string, params: TQueryParam[]): TQueryResponse;
|
|
8
|
+
}
|
|
9
|
+
export interface Driver<TSession> {
|
|
10
|
+
connect(): Promise<TSession>;
|
|
11
|
+
}
|
|
12
|
+
export interface Dialect<TSession, TDatabase> {
|
|
13
|
+
createDB(session: TSession): TDatabase;
|
|
14
|
+
migrate(migrations: MigrationMeta[], session: TSession): Promise<void>;
|
|
15
|
+
}
|
|
16
|
+
export interface Connector<TSession, TOperations> {
|
|
17
|
+
dialect: Dialect<TSession, TOperations>;
|
|
18
|
+
driver: Driver<TSession>;
|
|
19
|
+
}
|
|
20
|
+
export declare function connect<TSession, TDatabase>(connector: Connector<TSession, TDatabase>): Promise<TDatabase>;
|
|
21
|
+
export interface KitConfig {
|
|
22
|
+
out: string;
|
|
23
|
+
schema: string;
|
|
24
|
+
}
|
|
25
|
+
export interface MigrationConfig {
|
|
26
|
+
migrationsFolder: string;
|
|
27
|
+
}
|
|
28
|
+
export declare function migrate<TSession, TDatabase>(connector: Connector<TSession, TDatabase>, config: string): Promise<void>;
|
|
29
|
+
export declare function migrate<TSession, TDatabase>(connector: Connector<TSession, TDatabase>, config: MigrationConfig): Promise<void>;
|
package/connection.js
ADDED
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
26
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
27
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
28
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
29
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
30
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
31
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
32
|
+
});
|
|
33
|
+
};
|
|
34
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
35
|
+
exports.migrate = exports.connect = void 0;
|
|
36
|
+
const crypto = __importStar(require("crypto"));
|
|
37
|
+
const fs = __importStar(require("fs"));
|
|
38
|
+
const path = __importStar(require("path"));
|
|
39
|
+
function connect(connector) {
|
|
40
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
+
const session = yield connector.driver.connect();
|
|
42
|
+
return connector.dialect.createDB(session);
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
exports.connect = connect;
|
|
46
|
+
function migrate(connector, config) {
|
|
47
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
48
|
+
let migrationFolderTo;
|
|
49
|
+
if (typeof config === 'string') {
|
|
50
|
+
const configAsString = fs.readFileSync(path.resolve('.', config), 'utf8');
|
|
51
|
+
const jsonConfig = JSON.parse(configAsString);
|
|
52
|
+
migrationFolderTo = jsonConfig.out;
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
migrationFolderTo = config.migrationsFolder;
|
|
56
|
+
}
|
|
57
|
+
if (!migrationFolderTo) {
|
|
58
|
+
throw Error('no migration folder defined');
|
|
59
|
+
}
|
|
60
|
+
const files1 = fs.readdirSync(migrationFolderTo);
|
|
61
|
+
const migrationQueries = [];
|
|
62
|
+
for (const migrationFolder of files1) {
|
|
63
|
+
if (migrationFolder === '.DS_Store') {
|
|
64
|
+
continue;
|
|
65
|
+
}
|
|
66
|
+
const migrationFiles = fs.readdirSync(`${migrationFolderTo}/${migrationFolder}`);
|
|
67
|
+
const migrationFile = migrationFiles.filter((file) => file === 'migration.sql')[0];
|
|
68
|
+
const query = fs
|
|
69
|
+
.readFileSync(`${migrationFolderTo}/${migrationFolder}/${migrationFile}`)
|
|
70
|
+
.toString();
|
|
71
|
+
const year = Number(migrationFolder.slice(0, 4));
|
|
72
|
+
// second param for Date() is month index, that started from 0, so we need
|
|
73
|
+
// to decrement a value for month
|
|
74
|
+
const month = Number(migrationFolder.slice(4, 6)) - 1;
|
|
75
|
+
const day = Number(migrationFolder.slice(6, 8));
|
|
76
|
+
const hour = Number(migrationFolder.slice(8, 10));
|
|
77
|
+
const min = Number(migrationFolder.slice(10, 12));
|
|
78
|
+
const sec = Number(migrationFolder.slice(12, 14));
|
|
79
|
+
const folderAsMillis = Date.UTC(year, month, day, hour, min, sec);
|
|
80
|
+
migrationQueries.push({
|
|
81
|
+
sql: query,
|
|
82
|
+
folderMillis: folderAsMillis,
|
|
83
|
+
hash: crypto.createHash('sha256').update(query).digest('hex'),
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
const session = yield connector.driver.connect();
|
|
87
|
+
yield connector.dialect.migrate(migrationQueries, session);
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
exports.migrate = migrate;
|
|
91
|
+
//# sourceMappingURL=connection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connection.js","sourceRoot":"","sources":["../src/connection.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAiC;AACjC,uCAAyB;AACzB,2CAA6B;AAuB7B,SAAsB,OAAO,CAAsB,SAAyC;;QAC3F,MAAM,OAAO,GAAG,MAAM,SAAS,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QACjD,OAAO,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAC5C,CAAC;CAAA;AAHD,0BAGC;AAmBD,SAAsB,OAAO,CAC5B,SAAyC,EACzC,MAAgC;;QAEhC,IAAI,iBAAqC,CAAC;QAC1C,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE;YAC/B,MAAM,cAAc,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,CAAC;YAC1E,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAc,CAAC;YAC3D,iBAAiB,GAAG,UAAU,CAAC,GAAG,CAAC;SACnC;aAAM;YACN,iBAAiB,GAAG,MAAM,CAAC,gBAAgB,CAAC;SAC5C;QAED,IAAI,CAAC,iBAAiB,EAAE;YACvB,MAAM,KAAK,CAAC,6BAA6B,CAAC,CAAC;SAC3C;QAED,MAAM,MAAM,GAAG,EAAE,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC;QACjD,MAAM,gBAAgB,GAAoB,EAAE,CAAC;QAC7C,KAAK,MAAM,eAAe,IAAI,MAAM,EAAE;YACrC,IAAI,eAAe,KAAK,WAAW,EAAE;gBACpC,SAAS;aACT;YACD,MAAM,cAAc,GAAG,EAAE,CAAC,WAAW,CAAC,GAAG,iBAAiB,IAAI,eAAe,EAAE,CAAC,CAAC;YACjF,MAAM,aAAa,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,KAAK,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;YAEnF,MAAM,KAAK,GAAG,EAAE;iBACd,YAAY,CAAC,GAAG,iBAAiB,IAAI,eAAe,IAAI,aAAa,EAAE,CAAC;iBACxE,QAAQ,EAAE,CAAC;YAEb,MAAM,IAAI,GAAG,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACjD,0EAA0E;YAC1E,iCAAiC;YACjC,MAAM,KAAK,GAAG,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACtD,MAAM,GAAG,GAAG,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAChD,MAAM,IAAI,GAAG,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;YAClD,MAAM,GAAG,GAAG,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YAClD,MAAM,GAAG,GAAG,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;YAElD,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;YAClE,gBAAgB,CAAC,IAAI,CAAC;gBACrB,GAAG,EAAE,KAAK;gBACV,YAAY,EAAE,cAAc;gBAC5B,IAAI,EAAE,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;aAC7D,CAAC,CAAC;SACH;QAED,MAAM,OAAO,GAAG,MAAM,SAAS,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QACjD,MAAM,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAC;IAC5D,CAAC;CAAA;AAjDD,0BAiDC"}
|
package/expressions.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './sql/expressions';
|
package/expressions.js
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./sql/expressions"), exports);
|
|
18
|
+
//# sourceMappingURL=expressions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"expressions.js","sourceRoot":"","sources":["../src/expressions.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC"}
|
package/index.d.ts
CHANGED
|
@@ -1,13 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
export * from './
|
|
5
|
-
export * from './builders';
|
|
6
|
-
export * from './columns';
|
|
7
|
-
export * from './tables';
|
|
8
|
-
export * from './logger/consoleLogger';
|
|
9
|
-
export * from './logger/abstractLogger';
|
|
10
|
-
export declare const drizzle: {
|
|
11
|
-
connect(config: ClientConfig | string): Promise<DB>;
|
|
12
|
-
migrator(db: DB): Migrator;
|
|
13
|
-
};
|
|
1
|
+
export { sql } from './sql';
|
|
2
|
+
export * from './table';
|
|
3
|
+
export * from './column';
|
|
4
|
+
export * from './connection';
|
package/index.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -9,28 +13,11 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (functi
|
|
|
9
13
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
15
|
};
|
|
12
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
13
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
14
|
-
};
|
|
15
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
-
exports.
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
__exportStar(require("./
|
|
20
|
-
__exportStar(require("./
|
|
21
|
-
__exportStar(require("./
|
|
22
|
-
__exportStar(require("./tables"), exports);
|
|
23
|
-
__exportStar(require("./logger/consoleLogger"), exports);
|
|
24
|
-
__exportStar(require("./logger/abstractLogger"), exports);
|
|
25
|
-
exports.drizzle = {
|
|
26
|
-
async connect(config) {
|
|
27
|
-
if (typeof config === 'string') {
|
|
28
|
-
return new db_1.DbConnector().connectionString(config).connect();
|
|
29
|
-
}
|
|
30
|
-
return new db_1.DbConnector().params(config).connect();
|
|
31
|
-
},
|
|
32
|
-
migrator(db) {
|
|
33
|
-
return new migrator_1.default(db);
|
|
34
|
-
},
|
|
35
|
-
};
|
|
17
|
+
exports.sql = void 0;
|
|
18
|
+
var sql_1 = require("./sql");
|
|
19
|
+
Object.defineProperty(exports, "sql", { enumerable: true, get: function () { return sql_1.sql; } });
|
|
20
|
+
__exportStar(require("./table"), exports);
|
|
21
|
+
__exportStar(require("./column"), exports);
|
|
22
|
+
__exportStar(require("./connection"), exports);
|
|
36
23
|
//# sourceMappingURL=index.js.map
|
package/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,6BAA4B;AAAnB,0FAAA,GAAG,OAAA;AACZ,0CAAwB;AACxB,2CAAyB;AACzB,+CAA6B"}
|
package/operations.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ColumnData, ColumnDriverParam, TableName } from './branded-types';
|
|
2
|
+
import { AnyColumn, Column } from './column';
|
|
3
|
+
import { AnySQLResponse, SQLResponse } from './sql';
|
|
4
|
+
export declare type RequiredKeyOnly<TKey extends string, T extends AnyColumn> = T extends Column<any, any, any, infer TNotNull, infer THasDefault> ? [TNotNull, THasDefault] extends [true, false] | [] ? TKey : never : never;
|
|
5
|
+
export declare type OptionalKeyOnly<TKey extends string, T extends AnyColumn> = TKey extends RequiredKeyOnly<TKey, T> ? never : TKey;
|
|
6
|
+
export declare type SelectFields<TTableName extends TableName, TColumnDriverParam extends ColumnDriverParam = ColumnDriverParam> = {
|
|
7
|
+
[key: string]: SQLResponse<TTableName, ColumnData> | AnyColumn<TTableName, any, TColumnDriverParam>;
|
|
8
|
+
};
|
|
9
|
+
export declare type SelectFieldsOrdered = {
|
|
10
|
+
name: string;
|
|
11
|
+
resultTableName: string;
|
|
12
|
+
column: AnyColumn | AnySQLResponse;
|
|
13
|
+
}[];
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"operations.js","sourceRoot":"","sources":["../src/operations.ts"],"names":[],"mappings":""}
|
package/package.json
CHANGED
|
@@ -1,44 +1,71 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "drizzle-orm",
|
|
3
|
-
"version": "0.
|
|
4
|
-
"description": "",
|
|
5
|
-
"main": "
|
|
6
|
-
"types": "
|
|
3
|
+
"version": "0.12.0-beta.0",
|
|
4
|
+
"description": "Drizzle ORM package for SQL databases",
|
|
5
|
+
"main": "index.js",
|
|
6
|
+
"types": "index.d.ts",
|
|
7
7
|
"repository": {
|
|
8
8
|
"type": "git",
|
|
9
|
-
"url": "git+https://github.com/
|
|
10
|
-
"directory": "orm"
|
|
9
|
+
"url": "git+https://github.com/drizzle-team/drizzle-orm.git"
|
|
11
10
|
},
|
|
12
|
-
"keywords": [
|
|
11
|
+
"keywords": [
|
|
12
|
+
"orm",
|
|
13
|
+
"pg",
|
|
14
|
+
"mysql",
|
|
15
|
+
"postgresql",
|
|
16
|
+
"postgres",
|
|
17
|
+
"database",
|
|
18
|
+
"sql",
|
|
19
|
+
"typescript"
|
|
20
|
+
],
|
|
13
21
|
"author": "",
|
|
14
|
-
"license": "
|
|
22
|
+
"license": "Apache-2.0",
|
|
15
23
|
"bugs": {
|
|
16
|
-
"url": "https://github.com/
|
|
24
|
+
"url": "https://github.com/drizzle-team/drizzle-orm/issues"
|
|
25
|
+
},
|
|
26
|
+
"homepage": "https://github.com/drizzle-team/drizzle-orm#readme",
|
|
27
|
+
"peerDependencies": {
|
|
28
|
+
"drizzle-orm-mysql": ">=0.12.0-beta.0",
|
|
29
|
+
"drizzle-orm-pg": ">=0.12.0",
|
|
30
|
+
"mysql2": ">=2 <3",
|
|
31
|
+
"pg": ">=8 <9",
|
|
32
|
+
"sqlite3": ">=5 <6"
|
|
33
|
+
},
|
|
34
|
+
"peerDependenciesMeta": {
|
|
35
|
+
"mysql2": {
|
|
36
|
+
"optional": true
|
|
37
|
+
},
|
|
38
|
+
"pg": {
|
|
39
|
+
"optional": true
|
|
40
|
+
},
|
|
41
|
+
"sqlite3": {
|
|
42
|
+
"optional": true
|
|
43
|
+
},
|
|
44
|
+
"drizzle-orm-pg": {
|
|
45
|
+
"optional": true
|
|
46
|
+
},
|
|
47
|
+
"drizzle-orm-mysql": {
|
|
48
|
+
"optional": true
|
|
49
|
+
}
|
|
17
50
|
},
|
|
18
|
-
"homepage": "https://github.com/lambda-direct/drizzle-orm#readme",
|
|
19
51
|
"devDependencies": {
|
|
20
|
-
"@
|
|
21
|
-
"
|
|
22
|
-
"
|
|
23
|
-
"
|
|
24
|
-
"
|
|
25
|
-
"
|
|
26
|
-
"
|
|
27
|
-
"
|
|
28
|
-
"
|
|
29
|
-
"ts-node": "^10.0.0",
|
|
30
|
-
"typescript": "4.2.4",
|
|
31
|
-
"uvu": "^0.5.3"
|
|
52
|
+
"@types/pg": "^8.6.1",
|
|
53
|
+
"@types/sqlite3": "^3.1.8",
|
|
54
|
+
"mysql2": "^2.3.3",
|
|
55
|
+
"pg": "^8.6.0",
|
|
56
|
+
"resolve-tspaths": "^0.7.0",
|
|
57
|
+
"sqlite3": "^5.0.8",
|
|
58
|
+
"ts-node": "^10.8.2",
|
|
59
|
+
"typescript": "4.8.0-beta",
|
|
60
|
+
"uvu": "^0.5.6"
|
|
32
61
|
},
|
|
33
62
|
"dependencies": {
|
|
34
|
-
"
|
|
35
|
-
"pg": "^8.6.0"
|
|
63
|
+
"type-fest": "^2.16.0"
|
|
36
64
|
},
|
|
37
65
|
"scripts": {
|
|
38
|
-
"
|
|
39
|
-
"
|
|
40
|
-
"
|
|
41
|
-
"
|
|
42
|
-
}
|
|
43
|
-
"readme": "## DrizzleORM\nDrizzleORM is a TypeScript ORM library with a [drizzle-kit](https://www.npmjs.com/package/drizzle-kit) CLI companion for automatic SQL migrations generation. It's meant to be a library, not a framework, stay as an opt-in solution all the time at any levels. We try to follow SQL-like syntax whenever possible, be strongly typed ground top and fail in compile time, not in runtime. We implemented best in class `joins` and second to none `migrations generation`. Library has almost zero dependencies and being battle tested on production projects by multiple teams 🚀\n\n| database | support |\n|:-- | :---: |\n| PostgreSQL | ✅ |\n| MySQL | ⏳ |\n| DynamoDB | ⏳ |\n| SQLite | ⏳ |\n| MS SQL | ⏳ |\n| CockroachDB | ⏳ |\n\n### Installation\n```bash\nnpm install drizzle-orm drizzle-kit\n```\n\n### Quick start\n```typescript\nimport { drizzle, PgTable } from 'drizzle-orm'\n\nexport class UsersTable extends PgTable<UsersTable> {\n public id = this.serial('id').primaryKey();\n public fullName = this.text('full_name');\n public phone = this.varchar('phone', { size: 256 });\n\n public tableName(): string {\n return 'users';\n }\n}\nexport type User = InferType<UsersTable>\n\nconst db = await drizzle.connect(\"postgres://user:password@host:port/db\");\nconst usersTable = new UsersTable(db);\n\nconst users: User[] = await usersTable.select().execute();\n```\n\n### Connecting to database\n```typescript\n\nconst db = await drizzle.connect(\"postgres://user:password@host:port/db\");\nconst db = await drizzle.connect({\n host: \"127.0.0.1\",\n port: 5432,\n user: \"postgres\",\n password: \"postgres\",\n db: \"db_name\",\n});\n```\n\n### SQL schema declaration\nWith `drizzle-orm` you declare SQL schema in typescritp. You can have either one `schema.ts` file with all declarations or you can group them logically in multiple files. We prefer to use single file schema.\n```\n📦project\n ├ 📂src\n │ ├ 📂data\n │ │ └ 📜schema.ts\n │ └ ...\n ├ ...\n └ 📜package.json\n \n## or multiple schema files\n├ 📂data\n ├ 📜users.ts\n ├ 📜countries.ts\n ├ 📜cities.ts\n ├ 📜products.ts\n ├ 📜clients.ts\n ├ 📜enums.ts\n └ 📜etc.ts\n```\nThis is how you declare SQL schema in `schema.ts`. You can declare tables, indexes and constraints, foreign keys and enums. Please pay attention to `export` keyword, they are mandatory if you'll be using drizzle-kit SQL migrations generator.\n```typescript\n// declaring enum in database\nexport const popularityEnum = createEnum({ alias: 'popularity', values: ['unknown', 'known', 'popular'] });\n\nexport class CountriesTable extends PgTable<CountriesTable> {\n id = this.serial(\"id\").primaryKey();\n name = this.varchar(\"name\", { size: 256 })\n\t\n // declaring index\n nameIndex = this.uniqueIndex(this.name)\n\n public tableName(): string {\n return 'countries';\n }\n}\n\nexport class CitiesTable extends PgTable<CitiesTable> {\n id = this.serial(\"id\").primaryKey();\n name = this.varchar(\"name\", { size: 256 })\n countryId = this.int(\"country_id\").foreignKey(CountriesTable, (country) => country.id)\n\n // declaring enum column in table\n popularity = this.type(popularityEnum, \"popularity\")\n\n public tableName(): string {\n return 'cities';\n }\n}\n```\nThe list of all possible types. You can also create custom types - !!see here!!.\n```typescript\nexport const enum = createEnum({ alias: \"database-name\", values: [\"value1\", \"value2\", \"value3\"] });\ntype(enum, \"...\")\n\nsmallint(\"...\")\nint(\"...\")\nbigint(\"...\", maxBytes: \"max_bytes_53\")\nbigint(\"...\", maxBytes: \"max_bytes_64\")\n\nbool(\"...\")\ntext(\"...\");\nvarchar(\"...\");\nvarchar(\"...\", { size: 256 });\n\nserial(\"...\");\nbigserial(\"...\", maxBytes: \"max_bytes_53\");\nbigserial(\"...\", maxBytes: \"max_bytes_64\");\n\ndecimal(\"...\", { precision: 100, scale: 2 });\n\njsonb<...>(\"...\");\njsonb<string[]>(\"...\");\n\ntime(\"...\")\ntimestamp(\"...\") // with timezone\ntimestamptz(\"...\"); // without timezone\ntimestamp(\"...\").defaultValue(Defaults.CURRENT_TIMESTAMP)\n\nindex(column);\nindex([column1, column2, ...]);\nuniqueIndex(column);\nuniqueIndex([column1, column2, ...]);\n\n\ncolumn.primaryKey()\ncolumn.notNull()\ncolumn.defaultValue(...)\n\n// 'CASCADE' | 'RESTRICT' | 'SET NULL' | 'SET DEFAULT'\ncolumn.foreignKey(Table, (table) => table.column, { onDelete: \"CASCADE\", onUpdate: \"CASCADE\" });\n```\n\n### Create Read Update Delete\nQuerying, sorting and filtering. We also support partial select.\n```typescript\nconst db = await drizzle.connect(\"...\")\nconst table = new UsersTable(db);\n\nconst result: User[] = await table.select().execute();\nawait table.select().where(\n eq(table.id, 42)\n).execute();\n\n// you can combine filters with eq(...) or or(...)\nawait table.select().where(\n and([eq(table.id, 42), eq(table.name, \"Dan\")])\n).execute();\n\nawait table.select().where(\n or([eq(table.id, 42), eq(table.id, 1)])\n).execute();\n\n// partial select\nconst result = await table.select({\n mapped1: table.id,\n mapped2: table.name,\n}).execute();\nconst { mapped1, mapped2 } = result[0];\n\n// limit offset & order by\nawait table.select().limit(10).offset(10).execute()\nawait table.select().orderBy((table) => table.name, Order.ASC)\nawait table.select().orderBy((table) => table.name, Order.DESC)\n\n// list of all filter operators\neq(table.column, value)\nnotEq(table.column, value)\nless(table.column, value)\nlessEq(table.column, value)\ngreater(table.column, value)\ngreaterEq(table.column, value)\nisNull(table.column)\nisNotNull(table.column)\n\ninArray(table.column, [...values])\nlike(table.column, value)\nraw(\"raw sql filter\")\n\nand(exressions: Expr[])\nor(exressions: Expr[])\n```\nInserting\n```typescript\nconst result = await usersTable.insert({\n name: \"Andrew\",\n createdAt: new Date(),\n}).execute();\n\nconst result = await usersTable.insertMany([{\n name: \"Andrew\",\n createdAt: new Date(),\n}, {\n name: \"Dan\",\n createdAt: new Date(),\n}]).execute();\n\n//await usersTable.insert({\n// name: \"Dan\"\n//})\n//.onConflict(\n//\t(table) => table.name,\n//\t{ name: 'name value to be upserted' }\n//).execute();\n```\n\nUpdate and Delete\n```typescript\nawait usersTable.update()\n .where(eq(usersTable.name, 'Dan'))\n .set({ name: 'Mr. Dan' })\n .execute();\n\t\nawait usersTable.delete()\n .where(eq(usersTable.name, 'Dan'))\n .execute();\n```\n\n### Joins\nLast but not least. Probably the most powerful feature in the library🚀\nMany-to-one\n```typescript\nconst usersTable = new UsersTable(db);\nconst citiesTable = new CitiesTable(db);\n\nconst result = await citiesTable.select()\n .leftJoin(usersTable, (cities, users) => eq(cities.userId, users.id))\n .where((cities, users) => eq(cities.id, 1))\n .execute();\n\nconst citiesWithUsers: { city: City, user: User }[] = result.map((city, user) => ({ city, user }));\n```\nMany-to-many\n```typescript\nexport class UsersTable extends PgTable<UsersTable> {\n id = this.serial(\"id\").primaryKey();\n\tname = this.varchar(\"name\");\n}\n\nexport class ChatGroupsTable extends PgTable<ChatGroupsTable> {\n id = this.serial(\"id\").primaryKey();\n}\n\nexport class ManyToManyTable extends PgTable<ManyToManyTable> {\n userId = this.int('user_id').foreignKey(UsersTable, (table) => table.id, { onDelete: 'CASCADE' });\n groupId = this.int('group_id').foreignKey(ChatGroupsTable, (table) => table.id, { onDelete: 'CASCADE' });\n}\n\n...\nconst usersTable = new UsersTable(db);\nconst chatGroupsTable = new ChatGroupsTable(db);\nconst manyToManyTable = new ManyToManyTable(db);\n\n// querying user group with id 1 and all the participants(users)\nconst usersWithUserGroups = await manyToManyTable.select()\n .leftJoin(usersTable, (manyToMany, users) => eq(manyToManyTable.userId, users.id))\n .leftJoin(chatGroupsTable, (manyToMany, _users, chatGroups) => eq(manyToManyTable.groupId, chatGroups.id))\n .where((manyToMany, _users, userGroups) => eq(userGroups.id, 1))\n .execute();\n```\n\n### Join using partial field select\n##### Join Cities with Users getting only needed fields form request\n```typescript\n await citiesTable.select({\n id: citiesTable.id,\n userId: citiesTable.userId,\n })\n .leftJoin(usersTable, (cities, users) => eq(cities.userId, users.id))\n .where((cities, users) => eq(cities.id, 1))\n .execute();\n\nconst citiesWithUserObject = userWithCities.map((city, user) => ({ ...city, user }));\n```\n### Another join examples with different callback ON statements\n```typescript\nawait citiesTable.select()\n .leftJoin(usersTable, (cities, _users) => eq(cities.id, 13))\n .where((cities, _users) => eq(cities.location, 'q'))\n .execute();\n// Join statement generated from query\n// LEFT JOIN users AS users_1\n// ON cities.\"id\"=$1\n// WHERE cities.\"page\"=$2\n//\n// Values: [13, 'q']\n\nawait citiesTable.select()\n .leftJoin(usersTable, (cities, _users) => and([\n eq(cities.id, 13), notEq(cities.id, 14),\n ]))\n .execute();\n// Join statement generated from query\n// LEFT JOIN users AS users_1\n// ON (cities.\"id\"=$1 and cities.\"id\"!=$2)\n//\n// Values: [13, 14]\n\nawait citiesTable.select()\n .leftJoin(usersTable, (_cities, _users) => raw('<custom expression after ON statement>'))\n .where((cities, _users) => eq(cities.location, 'location'))\n .execute();\n// Join statement generated from query\n// LEFT JOIN users AS users_1\n// ON <custom expression after ON statement>\n// WHERE cities.\"page\"=$1\n// \n// Values: ['location']\n```\n\n\n## Migrations\n#### To run migrations generated by drizzle-kit you could use `Migrator` class\n##### Provide drizzle-kit config path\n```typescript\nawait drizzle.migrator(db).migrate('src/drizzle.config.yaml');\n```\n##### Another possibility is to provide object with path to folder with migrations\n```typescript\nawait drizzle.migrator(db).migrate({ migrationFolder: 'drizzle' });\n```\n\n\n## Raw query usage\n#### If you have some complex queries to execute and drizzle-orm can't handle them yet, then you could use `rawQuery` execution\n\n\n##### Execute custom raw query\n```typescript\nconst res: QueryResult<any> = await db.session().execute('SELECT * FROM users WHERE user.id = $1', [1]);\n```"
|
|
66
|
+
"build": "tsc",
|
|
67
|
+
"pack": "cp package.json dist/ && (cd dist && pnpm pack --pack-destination ..) && rm -f package.tgz && mv *.tgz package.tgz",
|
|
68
|
+
"publish:beta": "pnpm publish package.tgz --tag beta --access public --git-checks false",
|
|
69
|
+
"build:int": "pnpm build && pnpm run pack"
|
|
70
|
+
}
|
|
44
71
|
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { ColumnNotNull, TableName } from '../../branded-types';
|
|
2
|
+
import { AnyColumn, GetColumnData } from '../../column';
|
|
3
|
+
import { GetTableName } from '../../utils';
|
|
4
|
+
import { SQL, SQLWrapper } from '..';
|
|
5
|
+
export declare function eq<TColumn extends AnyColumn>(column: TColumn, value: GetColumnData<TColumn, 'raw'>): SQL<GetTableName<TColumn>>;
|
|
6
|
+
export declare function eq<TLeftTableName extends TableName, TRightTableName extends TableName>(left: AnyColumn<TLeftTableName>, right: AnyColumn<TRightTableName>): SQL<TLeftTableName | TRightTableName>;
|
|
7
|
+
export declare function ne<TColumn extends AnyColumn>(column: TColumn, value: GetColumnData<TColumn>): SQL<GetTableName<TColumn>>;
|
|
8
|
+
export declare function ne<TLeftTableName extends TableName, TRightTableName extends TableName>(left: AnyColumn<TLeftTableName>, right: AnyColumn<TRightTableName>): SQL<TLeftTableName | TRightTableName>;
|
|
9
|
+
export declare function and<TTableName extends TableName>(...conditions: (SQL<TTableName> | undefined)[]): SQL<TTableName> | undefined;
|
|
10
|
+
export declare function or<TTableName extends TableName>(...conditions: (SQL<TTableName> | undefined)[]): SQL<TTableName> | undefined;
|
|
11
|
+
export declare function not<TTableName extends TableName>(condition: SQL<TTableName>): SQL<TTableName>;
|
|
12
|
+
export declare function gt<TColumn extends AnyColumn>(column: TColumn, value: GetColumnData<TColumn>): SQL<GetTableName<TColumn>>;
|
|
13
|
+
export declare function gt<TLeftTableName extends TableName, TRightTableName extends TableName>(left: AnyColumn<TLeftTableName>, right: AnyColumn<TRightTableName>): SQL<TLeftTableName | TRightTableName>;
|
|
14
|
+
export declare function gte<TColumn extends AnyColumn>(column: TColumn, value: GetColumnData<TColumn> extends AnyColumn ? never : GetColumnData<TColumn>): SQL<GetTableName<TColumn>>;
|
|
15
|
+
export declare function gte<TLeftTableName extends TableName, TRightTableName extends TableName>(left: AnyColumn<TLeftTableName>, right: AnyColumn<TRightTableName>): SQL<TLeftTableName | TRightTableName>;
|
|
16
|
+
export declare function lt<TColumn extends AnyColumn>(column: TColumn, value: GetColumnData<TColumn> extends AnyColumn ? never : GetColumnData<TColumn>): SQL<GetTableName<TColumn>>;
|
|
17
|
+
export declare function lt<TLeftTableName extends TableName, TRightTableName extends TableName>(left: AnyColumn<TLeftTableName>, right: AnyColumn<TRightTableName>): SQL<TLeftTableName | TRightTableName>;
|
|
18
|
+
export declare function lte<TColumn extends AnyColumn>(column: TColumn, value: GetColumnData<TColumn> extends AnyColumn ? never : GetColumnData<TColumn>): SQL<GetTableName<TColumn>>;
|
|
19
|
+
export declare function lte<TLeftTableName extends TableName, TRightTableName extends TableName>(left: AnyColumn<TLeftTableName>, right: AnyColumn<TRightTableName>): SQL<TLeftTableName | TRightTableName>;
|
|
20
|
+
export declare function inArray<TColumn extends AnyColumn>(column: TColumn, values: GetColumnData<TColumn>[]): SQL<GetTableName<TColumn>>;
|
|
21
|
+
export declare function inArray<TColumn extends AnyColumn>(column: TColumn, subquery: SQLWrapper): SQL<GetTableName<TColumn>>;
|
|
22
|
+
export declare function notInArray<TColumn extends AnyColumn>(column: TColumn, values: GetColumnData<TColumn>[]): SQL<GetTableName<TColumn>>;
|
|
23
|
+
export declare function notInArray<TTableName extends TableName, TColumn extends AnyColumn<TTableName>>(column: TColumn, subquery: SQLWrapper): SQL<TTableName>;
|
|
24
|
+
export declare function isNull<TColumn extends AnyColumn<any, any, any, ColumnNotNull<false>>>(column: TColumn): SQL<GetTableName<TColumn>>;
|
|
25
|
+
export declare function isNotNull<TTableName extends TableName, TColumn extends AnyColumn<TTableName>>(column: TColumn): SQL<TTableName>;
|
|
26
|
+
export declare function exists<TTableName extends TableName>(subquery: SQLWrapper): SQL<TTableName>;
|
|
27
|
+
export declare function notExists<TTableName extends TableName>(subquery: SQLWrapper): SQL<TTableName>;
|
|
28
|
+
export declare function between<TTableName extends TableName, TColumn extends AnyColumn<TTableName>>(column: TColumn, min: GetColumnData<TColumn, 'raw'>, max: GetColumnData<TColumn, 'raw'>): SQL<TTableName>;
|
|
29
|
+
export declare function notBetween<TTableName extends TableName, TColumn extends AnyColumn<TTableName>>(column: TColumn, min: GetColumnData<TColumn, 'raw'>, max: GetColumnData<TColumn, 'raw'>): SQL<TTableName>;
|
|
30
|
+
export declare function like<TTableName extends TableName, TColumn extends AnyColumn<TTableName>>(column: TColumn, value: string): SQL<TTableName>;
|
|
31
|
+
export declare function notLike<TTableName extends TableName, TColumn extends AnyColumn<TTableName>>(column: TColumn, value: string): SQL<TTableName>;
|
|
32
|
+
export declare function ilike<TTableName extends TableName, TColumn extends AnyColumn<TTableName>>(column: TColumn, value: string): SQL<TTableName>;
|
|
33
|
+
export declare function notIlike<TTableName extends TableName, TColumn extends AnyColumn<TTableName>>(column: TColumn, value: string): SQL<TTableName>;
|