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.
Files changed (481) hide show
  1. package/LICENSE +674 -0
  2. package/{builders → dist/builders}/aggregators/abstractAggregator.d.ts +0 -0
  3. package/{builders → dist/builders}/aggregators/abstractAggregator.js +0 -0
  4. package/{builders → dist/builders}/aggregators/deleteAggregator.d.ts +0 -0
  5. package/{builders → dist/builders}/aggregators/deleteAggregator.js +4 -1
  6. package/{builders → dist/builders}/aggregators/insertAggregator.d.ts +0 -0
  7. package/{builders → dist/builders}/aggregators/insertAggregator.js +4 -1
  8. package/{builders → dist/builders}/aggregators/selectAggregator.d.ts +0 -0
  9. package/{builders → dist/builders}/aggregators/selectAggregator.js +24 -9
  10. package/{builders → dist/builders}/aggregators/updateAggregator.d.ts +0 -0
  11. package/{builders → dist/builders}/aggregators/updateAggregator.js +4 -1
  12. package/{builders → dist/builders}/highLvlBuilders/abstractRequestBuilder.d.ts +0 -0
  13. package/{builders → dist/builders}/highLvlBuilders/abstractRequestBuilder.js +0 -0
  14. package/{builders → dist/builders}/highLvlBuilders/deleteRequestBuilder.d.ts +0 -0
  15. package/{builders → dist/builders}/highLvlBuilders/deleteRequestBuilder.js +26 -4
  16. package/{builders → dist/builders}/highLvlBuilders/insertRequestBuilder.d.ts +0 -0
  17. package/{builders → dist/builders}/highLvlBuilders/insertRequestBuilder.js +26 -4
  18. package/{builders → dist/builders}/highLvlBuilders/order.d.ts +0 -0
  19. package/{builders → dist/builders}/highLvlBuilders/order.js +0 -0
  20. package/{builders → dist/builders}/highLvlBuilders/selectRequestBuilder.d.ts +0 -0
  21. package/{builders → dist/builders}/highLvlBuilders/selectRequestBuilder.js +26 -4
  22. package/{builders → dist/builders}/highLvlBuilders/updateRequestBuilder.d.ts +0 -0
  23. package/{builders → dist/builders}/highLvlBuilders/updateRequestBuilder.js +26 -4
  24. package/{builders → dist/builders}/index.d.ts +0 -0
  25. package/{builders → dist/builders}/index.js +19 -16
  26. package/{builders → dist/builders}/joinBuilders/builders/abstractJoinBuilder.d.ts +0 -0
  27. package/{builders → dist/builders}/joinBuilders/builders/abstractJoinBuilder.js +25 -3
  28. package/{builders → dist/builders}/joinBuilders/builders/selectWithFiveJoins.d.ts +0 -0
  29. package/{builders → dist/builders}/joinBuilders/builders/selectWithFiveJoins.js +5 -2
  30. package/{builders → dist/builders}/joinBuilders/builders/selectWithFourJoins.d.ts +0 -0
  31. package/{builders → dist/builders}/joinBuilders/builders/selectWithFourJoins.js +7 -4
  32. package/{builders → dist/builders}/joinBuilders/builders/selectWithJoin.d.ts +0 -0
  33. package/{builders → dist/builders}/joinBuilders/builders/selectWithJoin.js +7 -4
  34. package/{builders → dist/builders}/joinBuilders/builders/selectWithThreeJoins.d.ts +0 -0
  35. package/{builders → dist/builders}/joinBuilders/builders/selectWithThreeJoins.js +7 -4
  36. package/{builders → dist/builders}/joinBuilders/builders/selectWithTwoJoins.d.ts +0 -0
  37. package/{builders → dist/builders}/joinBuilders/builders/selectWithTwoJoins.js +7 -4
  38. package/{builders → dist/builders}/joinBuilders/join.d.ts +0 -0
  39. package/{builders → dist/builders}/joinBuilders/join.js +0 -0
  40. package/{builders → dist/builders}/joinBuilders/joinWith.d.ts +0 -0
  41. package/{builders → dist/builders}/joinBuilders/joinWith.js +4 -1
  42. package/{builders → dist/builders}/joinBuilders/responses/selectResponseFiveJoins.d.ts +0 -0
  43. package/{builders → dist/builders}/joinBuilders/responses/selectResponseFiveJoins.js +0 -0
  44. package/{builders → dist/builders}/joinBuilders/responses/selectResponseFourJoins.d.ts +0 -0
  45. package/{builders → dist/builders}/joinBuilders/responses/selectResponseFourJoins.js +0 -0
  46. package/{builders → dist/builders}/joinBuilders/responses/selectResponseThreeJoins.d.ts +0 -0
  47. package/{builders → dist/builders}/joinBuilders/responses/selectResponseThreeJoins.js +0 -0
  48. package/{builders → dist/builders}/joinBuilders/responses/selectResponseTwoJoins.d.ts +0 -0
  49. package/{builders → dist/builders}/joinBuilders/responses/selectResponseTwoJoins.js +0 -0
  50. package/{builders → dist/builders}/joinBuilders/responses/selectResponseWithJoin.d.ts +0 -0
  51. package/{builders → dist/builders}/joinBuilders/responses/selectResponseWithJoin.js +0 -0
  52. package/{builders → dist/builders}/joinBuilders/static.d.ts +0 -0
  53. package/{builders → dist/builders}/joinBuilders/static.js +4 -1
  54. package/{builders → dist/builders}/lowLvlBuilders/alter.d.ts +0 -0
  55. package/{builders → dist/builders}/lowLvlBuilders/alter.js +0 -0
  56. package/{builders → dist/builders}/lowLvlBuilders/create.d.ts +0 -0
  57. package/{builders → dist/builders}/lowLvlBuilders/create.js +4 -1
  58. package/{builders → dist/builders}/lowLvlBuilders/delets/delete.d.ts +0 -0
  59. package/{builders → dist/builders}/lowLvlBuilders/delets/delete.js +5 -2
  60. package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFilter.d.ts +0 -0
  61. package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFilter.js +0 -0
  62. package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFrom.d.ts +0 -0
  63. package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFrom.js +4 -1
  64. package/{builders → dist/builders}/lowLvlBuilders/inserts/insert.d.ts +0 -0
  65. package/{builders → dist/builders}/lowLvlBuilders/inserts/insert.js +5 -2
  66. package/{builders → dist/builders}/lowLvlBuilders/inserts/insertInto.d.ts +0 -0
  67. package/{builders → dist/builders}/lowLvlBuilders/inserts/insertInto.js +4 -1
  68. package/{builders → dist/builders}/lowLvlBuilders/inserts/onConflictInsert.d.ts +0 -0
  69. package/{builders → dist/builders}/lowLvlBuilders/inserts/onConflictInsert.js +0 -0
  70. package/{builders → dist/builders}/lowLvlBuilders/inserts/valuesInsert.d.ts +0 -0
  71. package/{builders → dist/builders}/lowLvlBuilders/inserts/valuesInsert.js +4 -1
  72. package/{builders → dist/builders}/lowLvlBuilders/selects/select.d.ts +0 -0
  73. package/{builders → dist/builders}/lowLvlBuilders/selects/select.js +5 -2
  74. package/{builders → dist/builders}/lowLvlBuilders/selects/selectFrom.d.ts +0 -0
  75. package/{builders → dist/builders}/lowLvlBuilders/selects/selectFrom.js +5 -2
  76. package/{builders → dist/builders}/lowLvlBuilders/selects/selectJoined.d.ts +0 -0
  77. package/{builders → dist/builders}/lowLvlBuilders/selects/selectJoined.js +4 -1
  78. package/{builders → dist/builders}/lowLvlBuilders/selects/whereSelect.d.ts +0 -0
  79. package/{builders → dist/builders}/lowLvlBuilders/selects/whereSelect.js +0 -0
  80. package/{builders → dist/builders}/lowLvlBuilders/updates/update.d.ts +0 -0
  81. package/{builders → dist/builders}/lowLvlBuilders/updates/update.js +5 -2
  82. package/{builders → dist/builders}/lowLvlBuilders/updates/updateIn.d.ts +0 -0
  83. package/{builders → dist/builders}/lowLvlBuilders/updates/updateIn.js +4 -1
  84. package/{builders → dist/builders}/lowLvlBuilders/updates/whereSelect.d.ts +0 -0
  85. package/{builders → dist/builders}/lowLvlBuilders/updates/whereSelect.js +0 -0
  86. package/{builders → dist/builders}/lowLvlBuilders/updates/whereSet.d.ts +0 -0
  87. package/{builders → dist/builders}/lowLvlBuilders/updates/whereSet.js +4 -1
  88. package/{builders → dist/builders}/requestBuilders/updates/combine.d.ts +0 -0
  89. package/{builders → dist/builders}/requestBuilders/updates/combine.js +0 -0
  90. package/{builders → dist/builders}/requestBuilders/updates/increment.d.ts +0 -0
  91. package/{builders → dist/builders}/requestBuilders/updates/increment.js +0 -0
  92. package/{builders → dist/builders}/requestBuilders/updates/setObjects.d.ts +0 -0
  93. package/{builders → dist/builders}/requestBuilders/updates/setObjects.js +5 -2
  94. package/{builders → dist/builders}/requestBuilders/updates/static.d.ts +0 -0
  95. package/{builders → dist/builders}/requestBuilders/updates/static.js +6 -3
  96. package/{builders → dist/builders}/requestBuilders/updates/updates.d.ts +0 -0
  97. package/{builders → dist/builders}/requestBuilders/updates/updates.js +0 -0
  98. package/{builders → dist/builders}/requestBuilders/where/and.d.ts +0 -0
  99. package/{builders → dist/builders}/requestBuilders/where/and.js +4 -1
  100. package/{builders → dist/builders}/requestBuilders/where/const.d.ts +0 -0
  101. package/{builders → dist/builders}/requestBuilders/where/const.js +4 -1
  102. package/{builders → dist/builders}/requestBuilders/where/constArray.d.ts +0 -0
  103. package/{builders → dist/builders}/requestBuilders/where/constArray.js +4 -1
  104. package/{builders → dist/builders}/requestBuilders/where/eqWhere.d.ts +0 -0
  105. package/{builders → dist/builders}/requestBuilders/where/eqWhere.js +4 -1
  106. package/{builders → dist/builders}/requestBuilders/where/greater.d.ts +0 -0
  107. package/{builders → dist/builders}/requestBuilders/where/greater.js +4 -1
  108. package/{builders → dist/builders}/requestBuilders/where/greaterEq.d.ts +0 -0
  109. package/{builders → dist/builders}/requestBuilders/where/greaterEq.js +4 -1
  110. package/{builders → dist/builders}/requestBuilders/where/in.d.ts +0 -0
  111. package/{builders → dist/builders}/requestBuilders/where/in.js +4 -1
  112. package/{builders → dist/builders}/requestBuilders/where/isNotNull.d.ts +0 -0
  113. package/{builders → dist/builders}/requestBuilders/where/isNotNull.js +4 -1
  114. package/{builders → dist/builders}/requestBuilders/where/isNull.d.ts +0 -0
  115. package/{builders → dist/builders}/requestBuilders/where/isNull.js +4 -1
  116. package/{builders → dist/builders}/requestBuilders/where/less.d.ts +0 -0
  117. package/{builders → dist/builders}/requestBuilders/where/less.js +4 -1
  118. package/{builders → dist/builders}/requestBuilders/where/lessEq.d.ts +0 -0
  119. package/{builders → dist/builders}/requestBuilders/where/lessEq.js +4 -1
  120. package/{builders → dist/builders}/requestBuilders/where/like.d.ts +0 -0
  121. package/{builders → dist/builders}/requestBuilders/where/like.js +4 -1
  122. package/{builders → dist/builders}/requestBuilders/where/notEqWhere.d.ts +0 -0
  123. package/{builders → dist/builders}/requestBuilders/where/notEqWhere.js +4 -1
  124. package/{builders → dist/builders}/requestBuilders/where/or.d.ts +0 -0
  125. package/{builders → dist/builders}/requestBuilders/where/or.js +4 -1
  126. package/{builders → dist/builders}/requestBuilders/where/rawWhere.d.ts +0 -0
  127. package/{builders → dist/builders}/requestBuilders/where/rawWhere.js +4 -1
  128. package/{builders → dist/builders}/requestBuilders/where/static.d.ts +0 -0
  129. package/{builders → dist/builders}/requestBuilders/where/static.js +19 -16
  130. package/{builders → dist/builders}/requestBuilders/where/var.d.ts +0 -0
  131. package/{builders → dist/builders}/requestBuilders/where/var.js +4 -1
  132. package/{builders → dist/builders}/requestBuilders/where/where.d.ts +0 -0
  133. package/{builders → dist/builders}/requestBuilders/where/where.js +0 -0
  134. package/{builders → dist/builders}/transaction/transaction.d.ts +0 -0
  135. package/{builders → dist/builders}/transaction/transaction.js +0 -0
  136. package/{columns → dist/columns}/column.d.ts +0 -0
  137. package/{columns → dist/columns}/column.js +0 -0
  138. package/{columns → dist/columns}/index.d.ts +0 -0
  139. package/{columns → dist/columns}/index.js +12 -9
  140. package/{columns → dist/columns}/types/columnType.d.ts +0 -0
  141. package/{columns → dist/columns}/types/columnType.js +0 -0
  142. package/{columns → dist/columns}/types/pgBigDecimal.d.ts +0 -0
  143. package/{columns → dist/columns}/types/pgBigDecimal.js +4 -1
  144. package/{columns → dist/columns}/types/pgBigInt.d.ts +0 -0
  145. package/{columns → dist/columns}/types/pgBigInt.js +4 -1
  146. package/{columns → dist/columns}/types/pgBigSerial.d.ts +0 -0
  147. package/{columns → dist/columns}/types/pgBigSerial.js +4 -1
  148. package/{columns → dist/columns}/types/pgBoolean.d.ts +0 -0
  149. package/{columns → dist/columns}/types/pgBoolean.js +4 -1
  150. package/{columns → dist/columns}/types/pgEnum.d.ts +0 -0
  151. package/{columns → dist/columns}/types/pgEnum.js +4 -1
  152. package/{columns → dist/columns}/types/pgInteger.d.ts +0 -0
  153. package/{columns → dist/columns}/types/pgInteger.js +4 -1
  154. package/{columns → dist/columns}/types/pgJsonb.d.ts +0 -0
  155. package/{columns → dist/columns}/types/pgJsonb.js +4 -1
  156. package/{columns → dist/columns}/types/pgSerial.d.ts +0 -0
  157. package/{columns → dist/columns}/types/pgSerial.js +4 -1
  158. package/{columns → dist/columns}/types/pgSmallInt.d.ts +0 -0
  159. package/{columns → dist/columns}/types/pgSmallInt.js +4 -1
  160. package/{columns → dist/columns}/types/pgText.d.ts +0 -0
  161. package/{columns → dist/columns}/types/pgText.js +4 -1
  162. package/{columns → dist/columns}/types/pgTime.d.ts +0 -0
  163. package/{columns → dist/columns}/types/pgTime.js +4 -1
  164. package/{columns → dist/columns}/types/pgTimestamp.d.ts +0 -0
  165. package/{columns → dist/columns}/types/pgTimestamp.js +4 -1
  166. package/{columns → dist/columns}/types/pgTimestamptz.d.ts +0 -0
  167. package/{columns → dist/columns}/types/pgTimestamptz.js +4 -1
  168. package/{columns → dist/columns}/types/pgVarChar.d.ts +0 -0
  169. package/{columns → dist/columns}/types/pgVarChar.js +4 -1
  170. package/{db → dist/db}/db.d.ts +0 -0
  171. package/{db → dist/db}/db.js +0 -0
  172. package/{db → dist/db}/dbConnector.d.ts +0 -0
  173. package/{db → dist/db}/dbConnector.js +6 -3
  174. package/{db → dist/db}/dbStringConnector.d.ts +0 -0
  175. package/{db → dist/db}/dbStringConnector.js +5 -2
  176. package/{db → dist/db}/group_by.d.ts +0 -0
  177. package/{db → dist/db}/group_by.js +0 -0
  178. package/{db → dist/db}/index.d.ts +0 -0
  179. package/{db → dist/db}/index.js +6 -3
  180. package/{db → dist/db}/session.d.ts +0 -0
  181. package/{db → dist/db}/session.js +0 -0
  182. package/{docs → dist/docs}/cases/simple_delete.d.ts +0 -0
  183. package/{docs → dist/docs}/cases/simple_delete.js +7 -4
  184. package/{docs → dist/docs}/cases/simple_insert.d.ts +0 -0
  185. package/{docs → dist/docs}/cases/simple_insert.js +8 -5
  186. package/{docs → dist/docs}/cases/simple_join.d.ts +0 -0
  187. package/{docs → dist/docs}/cases/simple_join.js +8 -5
  188. package/{docs → dist/docs}/cases/simple_select.d.ts +0 -0
  189. package/{docs → dist/docs}/cases/simple_select.js +6 -3
  190. package/{docs → dist/docs}/cases/simple_update.d.ts +0 -0
  191. package/{docs → dist/docs}/cases/simple_update.js +7 -4
  192. package/{docs → dist/docs}/tables/citiesTable.d.ts +0 -0
  193. package/{docs → dist/docs}/tables/citiesTable.js +6 -2
  194. package/{docs → dist/docs}/tables/userGroupsTable.d.ts +0 -0
  195. package/{docs → dist/docs}/tables/userGroupsTable.js +4 -1
  196. package/{docs → dist/docs}/tables/usersTable.d.ts +0 -0
  197. package/{docs → dist/docs}/tables/usersTable.js +4 -1
  198. package/{docs → dist/docs}/tables/usersToUserGroups.d.ts +0 -0
  199. package/{docs → dist/docs}/tables/usersToUserGroups.js +6 -3
  200. package/{docs → dist/docs}/types/rolesType.d.ts +0 -0
  201. package/{docs → dist/docs}/types/rolesType.js +0 -0
  202. package/{errors → dist/errors}/baseError.d.ts +0 -0
  203. package/{errors → dist/errors}/baseError.js +0 -0
  204. package/{errors → dist/errors}/builderError.d.ts +0 -0
  205. package/{errors → dist/errors}/builderError.js +2 -1
  206. package/{errors → dist/errors}/dbErrors.d.ts +0 -0
  207. package/{errors → dist/errors}/dbErrors.js +0 -0
  208. package/{index.d.ts → dist/index.d.ts} +0 -0
  209. package/{index.js → dist/index.js} +4 -1
  210. package/{indexes → dist/indexes}/tableIndex.d.ts +0 -0
  211. package/{indexes → dist/indexes}/tableIndex.js +0 -0
  212. package/{logger → dist/logger}/abstractLogger.d.ts +0 -0
  213. package/{logger → dist/logger}/abstractLogger.js +0 -0
  214. package/{logger → dist/logger}/consoleLogger.d.ts +0 -0
  215. package/{logger → dist/logger}/consoleLogger.js +4 -1
  216. package/{mappers → dist/mappers}/index.d.ts +0 -0
  217. package/{mappers → dist/mappers}/index.js +0 -0
  218. package/{mappers → dist/mappers}/responseMapper.d.ts +0 -0
  219. package/{mappers → dist/mappers}/responseMapper.js +0 -0
  220. package/{migrator → dist/migrator}/index.d.ts +0 -0
  221. package/{migrator → dist/migrator}/index.js +0 -0
  222. package/{migrator → dist/migrator}/migrator.d.ts +0 -0
  223. package/{migrator → dist/migrator}/migrator.js +26 -4
  224. package/dist/serializer/serializer.d.ts +47 -0
  225. package/dist/serializer/serializer.js +258 -0
  226. package/dist/src/builders/aggregators/abstractAggregator.d.ts +11 -0
  227. package/dist/src/builders/aggregators/abstractAggregator.js +35 -0
  228. package/dist/src/builders/aggregators/deleteAggregator.d.ts +16 -0
  229. package/dist/src/builders/aggregators/deleteAggregator.js +42 -0
  230. package/dist/src/builders/aggregators/insertAggregator.d.ts +22 -0
  231. package/dist/src/builders/aggregators/insertAggregator.js +106 -0
  232. package/dist/src/builders/aggregators/selectAggregator.d.ts +39 -0
  233. package/dist/src/builders/aggregators/selectAggregator.js +143 -0
  234. package/dist/src/builders/aggregators/updateAggregator.d.ts +19 -0
  235. package/dist/src/builders/aggregators/updateAggregator.js +50 -0
  236. package/dist/src/builders/highLvlBuilders/abstractRequestBuilder.d.ts +27 -0
  237. package/dist/src/builders/highLvlBuilders/abstractRequestBuilder.js +32 -0
  238. package/dist/src/builders/highLvlBuilders/deleteRequestBuilder.d.ts +19 -0
  239. package/dist/src/builders/highLvlBuilders/deleteRequestBuilder.js +61 -0
  240. package/dist/src/builders/highLvlBuilders/insertRequestBuilder.d.ts +20 -0
  241. package/dist/src/builders/highLvlBuilders/insertRequestBuilder.js +73 -0
  242. package/dist/src/builders/highLvlBuilders/order.d.ts +5 -0
  243. package/dist/src/builders/highLvlBuilders/order.js +8 -0
  244. package/dist/src/builders/highLvlBuilders/selectRequestBuilder.d.ts +47 -0
  245. package/dist/src/builders/highLvlBuilders/selectRequestBuilder.js +128 -0
  246. package/dist/src/builders/highLvlBuilders/updateRequestBuilder.d.ts +22 -0
  247. package/dist/src/builders/highLvlBuilders/updateRequestBuilder.js +80 -0
  248. package/dist/src/builders/index.d.ts +18 -0
  249. package/dist/src/builders/index.js +54 -0
  250. package/dist/src/builders/joinBuilders/builders/abstractJoinBuilder.d.ts +40 -0
  251. package/dist/src/builders/joinBuilders/builders/abstractJoinBuilder.js +78 -0
  252. package/dist/src/builders/joinBuilders/builders/selectWithFiveJoins.d.ts +35 -0
  253. package/dist/src/builders/joinBuilders/builders/selectWithFiveJoins.js +45 -0
  254. package/dist/src/builders/joinBuilders/builders/selectWithFourJoins.d.ts +55 -0
  255. package/dist/src/builders/joinBuilders/builders/selectWithFourJoins.js +78 -0
  256. package/dist/src/builders/joinBuilders/builders/selectWithJoin.d.ts +49 -0
  257. package/dist/src/builders/joinBuilders/builders/selectWithJoin.js +64 -0
  258. package/dist/src/builders/joinBuilders/builders/selectWithThreeJoins.d.ts +53 -0
  259. package/dist/src/builders/joinBuilders/builders/selectWithThreeJoins.js +73 -0
  260. package/dist/src/builders/joinBuilders/builders/selectWithTwoJoins.d.ts +51 -0
  261. package/dist/src/builders/joinBuilders/builders/selectWithTwoJoins.js +68 -0
  262. package/dist/src/builders/joinBuilders/join.d.ts +23 -0
  263. package/dist/src/builders/joinBuilders/join.js +28 -0
  264. package/dist/src/builders/joinBuilders/joinWith.d.ts +14 -0
  265. package/dist/src/builders/joinBuilders/joinWith.js +14 -0
  266. package/dist/src/builders/joinBuilders/responses/selectResponseFiveJoins.d.ts +20 -0
  267. package/dist/src/builders/joinBuilders/responses/selectResponseFiveJoins.js +35 -0
  268. package/dist/src/builders/joinBuilders/responses/selectResponseFourJoins.d.ts +19 -0
  269. package/dist/src/builders/joinBuilders/responses/selectResponseFourJoins.js +34 -0
  270. package/dist/src/builders/joinBuilders/responses/selectResponseThreeJoins.d.ts +18 -0
  271. package/dist/src/builders/joinBuilders/responses/selectResponseThreeJoins.js +33 -0
  272. package/dist/src/builders/joinBuilders/responses/selectResponseTwoJoins.d.ts +17 -0
  273. package/dist/src/builders/joinBuilders/responses/selectResponseTwoJoins.js +32 -0
  274. package/dist/src/builders/joinBuilders/responses/selectResponseWithJoin.d.ts +16 -0
  275. package/dist/src/builders/joinBuilders/responses/selectResponseWithJoin.js +31 -0
  276. package/dist/src/builders/joinBuilders/static.d.ts +5 -0
  277. package/dist/src/builders/joinBuilders/static.js +9 -0
  278. package/dist/src/builders/lowLvlBuilders/alter.d.ts +0 -0
  279. package/dist/src/builders/lowLvlBuilders/alter.js +1 -0
  280. package/dist/src/builders/lowLvlBuilders/create.d.ts +12 -0
  281. package/dist/src/builders/lowLvlBuilders/create.js +100 -0
  282. package/dist/src/builders/lowLvlBuilders/delets/delete.d.ts +5 -0
  283. package/dist/src/builders/lowLvlBuilders/delets/delete.js +15 -0
  284. package/dist/src/builders/lowLvlBuilders/delets/deleteFilter.d.ts +11 -0
  285. package/dist/src/builders/lowLvlBuilders/delets/deleteFilter.js +13 -0
  286. package/dist/src/builders/lowLvlBuilders/delets/deleteFrom.d.ts +12 -0
  287. package/dist/src/builders/lowLvlBuilders/delets/deleteFrom.js +14 -0
  288. package/dist/src/builders/lowLvlBuilders/inserts/insert.d.ts +5 -0
  289. package/dist/src/builders/lowLvlBuilders/inserts/insert.js +15 -0
  290. package/dist/src/builders/lowLvlBuilders/inserts/insertInto.d.ts +13 -0
  291. package/dist/src/builders/lowLvlBuilders/inserts/insertInto.js +16 -0
  292. package/dist/src/builders/lowLvlBuilders/inserts/onConflictInsert.d.ts +12 -0
  293. package/dist/src/builders/lowLvlBuilders/inserts/onConflictInsert.js +13 -0
  294. package/dist/src/builders/lowLvlBuilders/inserts/valuesInsert.d.ts +16 -0
  295. package/dist/src/builders/lowLvlBuilders/inserts/valuesInsert.js +19 -0
  296. package/dist/src/builders/lowLvlBuilders/selects/select.d.ts +9 -0
  297. package/dist/src/builders/lowLvlBuilders/selects/select.js +16 -0
  298. package/dist/src/builders/lowLvlBuilders/selects/selectFrom.d.ts +28 -0
  299. package/dist/src/builders/lowLvlBuilders/selects/selectFrom.js +34 -0
  300. package/dist/src/builders/lowLvlBuilders/selects/selectJoined.d.ts +26 -0
  301. package/dist/src/builders/lowLvlBuilders/selects/selectJoined.js +30 -0
  302. package/dist/src/builders/lowLvlBuilders/selects/whereSelect.d.ts +17 -0
  303. package/dist/src/builders/lowLvlBuilders/selects/whereSelect.js +25 -0
  304. package/dist/src/builders/lowLvlBuilders/updates/update.d.ts +5 -0
  305. package/dist/src/builders/lowLvlBuilders/updates/update.js +15 -0
  306. package/dist/src/builders/lowLvlBuilders/updates/updateIn.d.ts +13 -0
  307. package/dist/src/builders/lowLvlBuilders/updates/updateIn.js +15 -0
  308. package/dist/src/builders/lowLvlBuilders/updates/whereSelect.d.ts +11 -0
  309. package/dist/src/builders/lowLvlBuilders/updates/whereSelect.js +13 -0
  310. package/dist/src/builders/lowLvlBuilders/updates/whereSet.d.ts +14 -0
  311. package/dist/src/builders/lowLvlBuilders/updates/whereSet.js +18 -0
  312. package/dist/src/builders/requestBuilders/updates/combine.d.ts +9 -0
  313. package/dist/src/builders/requestBuilders/updates/combine.js +26 -0
  314. package/dist/src/builders/requestBuilders/updates/increment.d.ts +13 -0
  315. package/dist/src/builders/requestBuilders/updates/increment.js +18 -0
  316. package/dist/src/builders/requestBuilders/updates/setObjects.d.ts +12 -0
  317. package/dist/src/builders/requestBuilders/updates/setObjects.js +19 -0
  318. package/dist/src/builders/requestBuilders/updates/static.d.ts +7 -0
  319. package/dist/src/builders/requestBuilders/updates/static.js +15 -0
  320. package/dist/src/builders/requestBuilders/updates/updates.d.ts +9 -0
  321. package/dist/src/builders/requestBuilders/updates/updates.js +10 -0
  322. package/dist/src/builders/requestBuilders/where/and.d.ts +11 -0
  323. package/dist/src/builders/requestBuilders/where/and.js +31 -0
  324. package/dist/src/builders/requestBuilders/where/const.d.ts +9 -0
  325. package/dist/src/builders/requestBuilders/where/const.js +25 -0
  326. package/dist/src/builders/requestBuilders/where/constArray.d.ts +9 -0
  327. package/dist/src/builders/requestBuilders/where/constArray.js +39 -0
  328. package/dist/src/builders/requestBuilders/where/eqWhere.d.ts +12 -0
  329. package/dist/src/builders/requestBuilders/where/eqWhere.js +20 -0
  330. package/dist/src/builders/requestBuilders/where/greater.d.ts +15 -0
  331. package/dist/src/builders/requestBuilders/where/greater.js +20 -0
  332. package/dist/src/builders/requestBuilders/where/greaterEq.d.ts +15 -0
  333. package/dist/src/builders/requestBuilders/where/greaterEq.js +20 -0
  334. package/dist/src/builders/requestBuilders/where/in.d.ts +12 -0
  335. package/dist/src/builders/requestBuilders/where/in.js +20 -0
  336. package/dist/src/builders/requestBuilders/where/isNotNull.d.ts +11 -0
  337. package/dist/src/builders/requestBuilders/where/isNotNull.js +18 -0
  338. package/dist/src/builders/requestBuilders/where/isNull.d.ts +11 -0
  339. package/dist/src/builders/requestBuilders/where/isNull.js +18 -0
  340. package/dist/src/builders/requestBuilders/where/less.d.ts +15 -0
  341. package/dist/src/builders/requestBuilders/where/less.js +20 -0
  342. package/dist/src/builders/requestBuilders/where/lessEq.d.ts +15 -0
  343. package/dist/src/builders/requestBuilders/where/lessEq.js +20 -0
  344. package/dist/src/builders/requestBuilders/where/like.d.ts +12 -0
  345. package/dist/src/builders/requestBuilders/where/like.js +20 -0
  346. package/dist/src/builders/requestBuilders/where/notEqWhere.d.ts +12 -0
  347. package/dist/src/builders/requestBuilders/where/notEqWhere.js +20 -0
  348. package/dist/src/builders/requestBuilders/where/or.d.ts +11 -0
  349. package/dist/src/builders/requestBuilders/where/or.js +31 -0
  350. package/dist/src/builders/requestBuilders/where/rawWhere.d.ts +9 -0
  351. package/dist/src/builders/requestBuilders/where/rawWhere.js +15 -0
  352. package/dist/src/builders/requestBuilders/where/static.d.ts +17 -0
  353. package/dist/src/builders/requestBuilders/where/static.js +49 -0
  354. package/dist/src/builders/requestBuilders/where/var.d.ts +13 -0
  355. package/dist/src/builders/requestBuilders/where/var.js +18 -0
  356. package/dist/src/builders/requestBuilders/where/where.d.ts +8 -0
  357. package/dist/src/builders/requestBuilders/where/where.js +6 -0
  358. package/dist/src/builders/transaction/transaction.d.ts +8 -0
  359. package/dist/src/builders/transaction/transaction.js +20 -0
  360. package/dist/src/columns/column.d.ts +72 -0
  361. package/dist/src/columns/column.js +101 -0
  362. package/dist/src/columns/index.d.ts +10 -0
  363. package/dist/src/columns/index.js +27 -0
  364. package/dist/src/columns/types/columnType.d.ts +7 -0
  365. package/dist/src/columns/types/columnType.js +6 -0
  366. package/dist/src/columns/types/pgBigDecimal.d.ts +10 -0
  367. package/dist/src/columns/types/pgBigDecimal.js +31 -0
  368. package/dist/src/columns/types/pgBigInt.d.ts +15 -0
  369. package/dist/src/columns/types/pgBigInt.js +32 -0
  370. package/dist/src/columns/types/pgBigSerial.d.ts +15 -0
  371. package/dist/src/columns/types/pgBigSerial.js +32 -0
  372. package/dist/src/columns/types/pgBoolean.d.ts +8 -0
  373. package/dist/src/columns/types/pgBoolean.js +18 -0
  374. package/dist/src/columns/types/pgEnum.d.ts +9 -0
  375. package/dist/src/columns/types/pgEnum.js +18 -0
  376. package/dist/src/columns/types/pgInteger.d.ts +8 -0
  377. package/dist/src/columns/types/pgInteger.js +21 -0
  378. package/dist/src/columns/types/pgJsonb.d.ts +9 -0
  379. package/dist/src/columns/types/pgJsonb.js +20 -0
  380. package/dist/src/columns/types/pgSerial.d.ts +8 -0
  381. package/dist/src/columns/types/pgSerial.js +18 -0
  382. package/dist/src/columns/types/pgSmallInt.d.ts +8 -0
  383. package/dist/src/columns/types/pgSmallInt.js +18 -0
  384. package/dist/src/columns/types/pgText.d.ts +8 -0
  385. package/dist/src/columns/types/pgText.js +18 -0
  386. package/dist/src/columns/types/pgTime.d.ts +8 -0
  387. package/dist/src/columns/types/pgTime.js +18 -0
  388. package/dist/src/columns/types/pgTimestamp.d.ts +8 -0
  389. package/dist/src/columns/types/pgTimestamp.js +18 -0
  390. package/dist/src/columns/types/pgTimestamptz.d.ts +8 -0
  391. package/dist/src/columns/types/pgTimestamptz.js +18 -0
  392. package/dist/src/columns/types/pgVarChar.d.ts +9 -0
  393. package/dist/src/columns/types/pgVarChar.js +24 -0
  394. package/dist/src/db/db.d.ts +18 -0
  395. package/dist/src/db/db.js +25 -0
  396. package/dist/src/db/dbConnector.d.ts +9 -0
  397. package/dist/src/db/dbConnector.js +32 -0
  398. package/dist/src/db/dbStringConnector.d.ts +6 -0
  399. package/dist/src/db/dbStringConnector.js +29 -0
  400. package/dist/src/db/group_by.d.ts +0 -0
  401. package/dist/src/db/group_by.js +68 -0
  402. package/dist/src/db/index.d.ts +4 -0
  403. package/dist/src/db/index.js +14 -0
  404. package/dist/src/db/session.d.ts +9 -0
  405. package/dist/src/db/session.js +16 -0
  406. package/{test.d.ts → dist/src/docs/cases/simple_delete.d.ts} +0 -0
  407. package/dist/src/docs/cases/simple_delete.js +35 -0
  408. package/dist/src/docs/cases/simple_insert.d.ts +1 -0
  409. package/dist/src/docs/cases/simple_insert.js +57 -0
  410. package/dist/src/docs/cases/simple_join.d.ts +1 -0
  411. package/dist/src/docs/cases/simple_join.js +115 -0
  412. package/dist/src/docs/cases/simple_select.d.ts +1 -0
  413. package/dist/src/docs/cases/simple_select.js +50 -0
  414. package/dist/src/docs/cases/simple_update.d.ts +1 -0
  415. package/dist/src/docs/cases/simple_update.js +39 -0
  416. package/dist/src/docs/tables/citiesTable.d.ts +14 -0
  417. package/dist/src/docs/tables/citiesTable.js +21 -0
  418. package/dist/src/docs/tables/userGroupsTable.d.ts +7 -0
  419. package/dist/src/docs/tables/userGroupsTable.js +18 -0
  420. package/dist/src/docs/tables/usersTable.d.ts +17 -0
  421. package/dist/src/docs/tables/usersTable.js +35 -0
  422. package/dist/src/docs/tables/usersToUserGroups.d.ts +7 -0
  423. package/dist/src/docs/tables/usersToUserGroups.js +20 -0
  424. package/dist/src/docs/types/rolesType.d.ts +1 -0
  425. package/dist/src/docs/types/rolesType.js +6 -0
  426. package/dist/src/errors/baseError.d.ts +22 -0
  427. package/dist/src/errors/baseError.js +35 -0
  428. package/dist/src/errors/builderError.d.ts +14 -0
  429. package/dist/src/errors/builderError.js +25 -0
  430. package/dist/src/errors/dbErrors.d.ts +12 -0
  431. package/dist/src/errors/dbErrors.js +28 -0
  432. package/dist/src/index.d.ts +11 -0
  433. package/dist/src/index.js +31 -0
  434. package/dist/src/indexes/tableIndex.d.ts +11 -0
  435. package/dist/src/indexes/tableIndex.js +17 -0
  436. package/dist/src/logger/abstractLogger.d.ts +4 -0
  437. package/dist/src/logger/abstractLogger.js +5 -0
  438. package/dist/src/logger/consoleLogger.d.ts +5 -0
  439. package/dist/src/logger/consoleLogger.js +15 -0
  440. package/dist/src/mappers/index.d.ts +0 -0
  441. package/dist/src/mappers/index.js +1 -0
  442. package/dist/src/mappers/responseMapper.d.ts +10 -0
  443. package/dist/src/mappers/responseMapper.js +35 -0
  444. package/dist/src/migrator/index.d.ts +0 -0
  445. package/dist/src/migrator/index.js +1 -0
  446. package/dist/src/migrator/migrator.d.ts +11 -0
  447. package/dist/src/migrator/migrator.js +105 -0
  448. package/{serializer → dist/src/serializer}/serializer.d.ts +0 -0
  449. package/{serializer → dist/src/serializer}/serializer.js +4 -1
  450. package/{tables → dist/src/tables}/abstractTable.d.ts +0 -0
  451. package/{tables → dist/src/tables}/abstractTable.js +41 -19
  452. package/{tables → dist/src/tables}/index.d.ts +0 -0
  453. package/{tables → dist/src/tables}/index.js +5 -2
  454. package/{tables → dist/src/tables}/inferTypes.d.ts +0 -0
  455. package/{tables → dist/src/tables}/inferTypes.js +0 -0
  456. package/{tables → dist/src/tables}/migrationsTable.d.ts +0 -0
  457. package/{tables → dist/src/tables}/migrationsTable.js +4 -1
  458. package/dist/src/test.d.ts +1 -0
  459. package/{test.js → dist/src/test.js} +23 -8
  460. package/{types → dist/src/types}/type.d.ts +0 -0
  461. package/{types → dist/src/types}/type.js +0 -0
  462. package/{utils → dist/src/utils}/ecranate.d.ts +0 -0
  463. package/{utils → dist/src/utils}/ecranate.js +0 -0
  464. package/dist/tables/abstractTable.d.ts +68 -0
  465. package/dist/tables/abstractTable.js +151 -0
  466. package/dist/tables/index.d.ts +3 -0
  467. package/dist/tables/index.js +11 -0
  468. package/dist/tables/inferTypes.d.ts +39 -0
  469. package/dist/tables/inferTypes.js +2 -0
  470. package/dist/tables/migrationsTable.d.ts +7 -0
  471. package/dist/tables/migrationsTable.js +18 -0
  472. package/dist/test.d.ts +1 -0
  473. package/dist/test.js +65 -0
  474. package/dist/tsconfig.tsbuildinfo +5054 -0
  475. package/dist/types/type.d.ts +10 -0
  476. package/dist/types/type.js +14 -0
  477. package/dist/utils/ecranate.d.ts +2 -0
  478. package/dist/utils/ecranate.js +8 -0
  479. package/package.json +18 -13
  480. package/tables/aggregators.d.ts +0 -27
  481. package/tables/aggregators.js +0 -56
@@ -0,0 +1,115 @@
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
+ /* eslint-disable max-len */
7
+ /* eslint-disable @typescript-eslint/no-unused-vars */
8
+ const __1 = require("../..");
9
+ const builders_1 = require("../../builders");
10
+ const consoleLogger_1 = __importDefault(require("../../logger/consoleLogger"));
11
+ const citiesTable_1 = __importDefault(require("../tables/citiesTable"));
12
+ const userGroupsTable_1 = __importDefault(require("../tables/userGroupsTable"));
13
+ const usersTable_1 = __importDefault(require("../tables/usersTable"));
14
+ const usersToUserGroups_1 = __importDefault(require("../tables/usersToUserGroups"));
15
+ (async () => {
16
+ var _a, _b, _c, _d, _e, _f;
17
+ try {
18
+ const db = await new __1.DbConnector()
19
+ .connectionString('postgresql://postgres@127.0.0.1/migrator')
20
+ .connect();
21
+ db.useLogger(new consoleLogger_1.default());
22
+ const usersTable = new usersTable_1.default(db);
23
+ const citiesTable = new citiesTable_1.default(db);
24
+ const usersToUserGroupsTable = new usersToUserGroups_1.default(db);
25
+ const userGroupsTable = new userGroupsTable_1.default(db);
26
+ // await db.session().execute(Create.table(usersTable).build());
27
+ // await db.session().execute(Create.table(citiesTable).build());
28
+ // await db.session().execute(Create.table(userGroupsTable).build());
29
+ // await db.session().execute(Create.table(usersToUserGroupsTable).build());
30
+ const userRes = await usersTable.insertMany([{
31
+ decimalField: 4.2,
32
+ createdAt: new Date(),
33
+ role: 'foo',
34
+ }, {
35
+ decimalField: 5.8,
36
+ createdAt: new Date(),
37
+ role: 'foo',
38
+ }]).all();
39
+ const citiesRes = await citiesTable.insertMany([{
40
+ foundationDate: new Date(),
41
+ userId: (_a = userRes[0]) === null || _a === void 0 ? void 0 : _a.id,
42
+ }, {
43
+ foundationDate: new Date(),
44
+ userId: (_b = userRes[1]) === null || _b === void 0 ? void 0 : _b.id,
45
+ }]).all();
46
+ const userGroups = await userGroupsTable.insertMany([{
47
+ name: 'firstGroup',
48
+ }, {
49
+ name: 'secondGroup',
50
+ }]).all();
51
+ await usersToUserGroupsTable.insertMany([{
52
+ userId: (_c = userRes[0]) === null || _c === void 0 ? void 0 : _c.id,
53
+ groupId: (_d = userGroups[0]) === null || _d === void 0 ? void 0 : _d.id,
54
+ },
55
+ {
56
+ userId: (_e = userRes[1]) === null || _e === void 0 ? void 0 : _e.id,
57
+ groupId: (_f = userGroups[1]) === null || _f === void 0 ? void 0 : _f.id,
58
+ }]).execute();
59
+ // map case
60
+ const userWithCities = await citiesTable.select()
61
+ .where(builders_1.eq(citiesTable.id, 1))
62
+ .leftJoin(usersTable_1.default, (city) => city.userId, (users) => users.id)
63
+ .execute();
64
+ const citiesWithUserObject = userWithCities.map((city, user) => ({ ...city, user }));
65
+ // foreach case
66
+ // const userWithCities1 = await citiesTable.select()
67
+ // .where(eq(citiesTable.id, 1))
68
+ // .leftJoin(UsersTable,
69
+ // (city) => city.userId,
70
+ // (users) => users.id)
71
+ // .execute();
72
+ // let user;
73
+ // const cities = [];
74
+ // userWithCities.foreach((dbCity, dbUser) => {
75
+ // cities.push(dbCity);
76
+ // user = dbUser;
77
+ // });
78
+ // const usersTable = new UsersTable(db);
79
+ // const citiesTable = new CitiesTable(db);
80
+ const sdf = await citiesTable.select({
81
+ id: citiesTable.id,
82
+ userId: citiesTable.userId,
83
+ }).where(builders_1.eq(citiesTable.id, 1))
84
+ .leftJoin(usersTable_1.default, (city) => city.userId, (users) => users.id, {
85
+ id: usersTable.id,
86
+ })
87
+ .execute();
88
+ // group case
89
+ const usersWithUserGroups = await usersToUserGroupsTable.select()
90
+ .where(builders_1.eq(userGroupsTable.id, 1))
91
+ .leftJoin(usersTable_1.default, (userToGroup) => userToGroup.userId, (users) => users.id, {
92
+ id: usersTable.id,
93
+ })
94
+ .leftJoin(usersToUserGroups_1.default, userGroupsTable_1.default, (userToGroup) => userToGroup.groupId, (userGroup) => userGroup.id, {
95
+ id: userGroupsTable.id,
96
+ })
97
+ .execute();
98
+ const userGroupWithUsers = usersWithUserGroups.group({
99
+ one: (_, dbUser, dbUserGroup) => dbUser,
100
+ many: (_, dbUser, dbUserGroup) => dbUserGroup,
101
+ });
102
+ // const userWithGroups: ExtractModel<UsersTable> & { groups: ExtractModel<UserGroupsTable>[] } = {
103
+ // ...userGroupWithUsers.one,
104
+ // groups: userGroupWithUsers.many,
105
+ // };
106
+ // console.log('city', city!);
107
+ // console.log('cityUsers', cityUsers);
108
+ // console.log('cityWithUsers', forEachCities);
109
+ // console.log('cityWithUsers1', forEachUsers);
110
+ // how to handle many-to-many relations
111
+ }
112
+ catch (e) {
113
+ console.log(e);
114
+ }
115
+ })();
@@ -0,0 +1 @@
1
+ export {};
@@ -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
+ /* eslint-disable @typescript-eslint/no-unused-vars */
7
+ const __1 = require("../..");
8
+ const builders_1 = require("../../builders");
9
+ const order_1 = __importDefault(require("../../builders/highLvlBuilders/order"));
10
+ const static_1 = require("../../builders/requestBuilders/where/static");
11
+ const consoleLogger_1 = __importDefault(require("../../logger/consoleLogger"));
12
+ const usersTable_1 = __importDefault(require("../tables/usersTable"));
13
+ (async () => {
14
+ try {
15
+ const db = await new __1.DbConnector()
16
+ .connectionString('postgresql://postgres@127.0.0.1/migrator')
17
+ .connect();
18
+ const usersTable = new usersTable_1.default(db);
19
+ db.useLogger(new consoleLogger_1.default());
20
+ // select all
21
+ const allSelect = await usersTable.select().all();
22
+ // select first
23
+ const firstSelect = await usersTable.select().all();
24
+ // select using filters
25
+ const eqSelect = await usersTable.select().where(builders_1.eq(usersTable.phone, 'hello')).all();
26
+ const andSelect = await usersTable.select().where(builders_1.and([builders_1.eq(usersTable.phone, 'hello')])).all();
27
+ const orSelect = await usersTable.select().where(builders_1.or([builders_1.eq(usersTable.phone, 'hello')])).all();
28
+ // select using limit, offset
29
+ const limitOffsetSelect = await usersTable.select().limit(20).offset(20).all();
30
+ const likeSelect = await usersTable.select().where(builders_1.like(usersTable.phone, 'hello')).all();
31
+ const inArraySelect = await usersTable.select().where(static_1.inArray(usersTable.phone, ['hello'])).all();
32
+ const greaterSelect = await usersTable.select().where(static_1.greater(usersTable.bigIntField, 3)).all();
33
+ const lessSelect = await usersTable.select().where(static_1.less(usersTable.bigIntField, 3)).all();
34
+ const greaterEqSelect = await usersTable.select().where(static_1.greaterEq(usersTable.bigIntField, 3))
35
+ .all();
36
+ const lessEqSelect = await usersTable.select().where(static_1.lessEq(usersTable.bigIntField, 3));
37
+ const isNullSelect = await usersTable.select().where(static_1.isNull(usersTable.phone)).all();
38
+ const notEqSelect = await usersTable.select().where(static_1.notEq(usersTable.phone, 'hello')).all();
39
+ const partialSelect = await usersTable.select({
40
+ mappedId: usersTable.id,
41
+ mappedPhone: usersTable.phone,
42
+ }).all();
43
+ // const { mappedId, mappedPhone } = partialSelect;
44
+ // ordered select
45
+ const ordered = await usersTable.select().orderBy((table) => table.phone, order_1.default.ASC).all();
46
+ }
47
+ catch (e) {
48
+ console.log(e);
49
+ }
50
+ })();
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,39 @@
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
+ /* eslint-disable @typescript-eslint/no-unused-vars */
7
+ const __1 = require("../..");
8
+ const builders_1 = require("../../builders");
9
+ const consoleLogger_1 = __importDefault(require("../../logger/consoleLogger"));
10
+ const citiesTable_1 = __importDefault(require("../tables/citiesTable"));
11
+ const userGroupsTable_1 = __importDefault(require("../tables/userGroupsTable"));
12
+ const usersTable_1 = __importDefault(require("../tables/usersTable"));
13
+ (async () => {
14
+ try {
15
+ const db = await new __1.DbConnector()
16
+ .connectionString('postgresql://postgres@127.0.0.1/migrator')
17
+ .connect();
18
+ db.useLogger(new consoleLogger_1.default());
19
+ const usersTable = new usersTable_1.default(db);
20
+ const citiesTable = new citiesTable_1.default(db);
21
+ const userGroupsTable = new userGroupsTable_1.default(db);
22
+ await usersTable.update()
23
+ .where(builders_1.eq(usersTable.phone, 'hello'))
24
+ .set({ fullName: 'newName' })
25
+ .execute();
26
+ const updatedCities = await citiesTable.update()
27
+ .where(builders_1.eq(citiesTable.location, 'USA'))
28
+ .set({ metadata: { population: 1, connection: 'first' } })
29
+ .all();
30
+ console.log(updatedCities);
31
+ const updatedUserGroup = await userGroupsTable.update()
32
+ .where(builders_1.eq(userGroupsTable.id, 1))
33
+ .set({ description: 'updated description' })
34
+ .all();
35
+ }
36
+ catch (e) {
37
+ console.log(e);
38
+ }
39
+ })();
@@ -0,0 +1,14 @@
1
+ import AbstractTable from '../../tables/abstractTable';
2
+ interface CityMeta {
3
+ population: number;
4
+ connection: string;
5
+ }
6
+ export default class CitiesTable extends AbstractTable<CitiesTable> {
7
+ id: import("../..").Column<import("../../columns/types/pgSerial").default, true, true, this>;
8
+ foundationDate: import("../..").Column<import("../..").PgTimestamp, false, false, this>;
9
+ location: import("../..").Column<import("../..").PgVarChar, true, false, this>;
10
+ userId: import("../..").Column<import("../..").PgInteger, true, false, this>;
11
+ metadata: import("../..").Column<import("../..").PgJsonb<CityMeta>, true, false, this>;
12
+ tableName(): string;
13
+ }
14
+ export {};
@@ -0,0 +1,21 @@
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 abstractTable_1 = __importDefault(require("../../tables/abstractTable"));
7
+ const usersTable_1 = __importDefault(require("./usersTable"));
8
+ class CitiesTable extends abstractTable_1.default {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.id = this.serial('id').primaryKey();
12
+ this.foundationDate = this.timestamp('name').notNull();
13
+ this.location = this.varchar('page', { size: 256 });
14
+ this.userId = this.int('user_id').foreignKey(usersTable_1.default, (table) => table.id, { onUpdate: 'CASCADE' });
15
+ this.metadata = this.jsonb('metadata');
16
+ }
17
+ tableName() {
18
+ return 'cities';
19
+ }
20
+ }
21
+ exports.default = CitiesTable;
@@ -0,0 +1,7 @@
1
+ import AbstractTable from '../../tables/abstractTable';
2
+ export default class UserGroupsTable extends AbstractTable<UserGroupsTable> {
3
+ id: import("../..").Column<import("../../columns/types/pgSerial").default, true, true, this>;
4
+ name: import("../..").Column<import("../..").PgVarChar, true, false, this>;
5
+ description: import("../..").Column<import("../..").PgVarChar, true, false, this>;
6
+ tableName(): string;
7
+ }
@@ -0,0 +1,18 @@
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 abstractTable_1 = __importDefault(require("../../tables/abstractTable"));
7
+ class UserGroupsTable extends abstractTable_1.default {
8
+ constructor() {
9
+ super(...arguments);
10
+ this.id = this.serial('id').primaryKey();
11
+ this.name = this.varchar('name');
12
+ this.description = this.varchar('description');
13
+ }
14
+ tableName() {
15
+ return 'user_groups';
16
+ }
17
+ }
18
+ exports.default = UserGroupsTable;
@@ -0,0 +1,17 @@
1
+ import AbstractTable from '../../tables/abstractTable';
2
+ export declare const rolesEnum: import("../../types/type").default<"foo" | "bar" | "baz">;
3
+ export default class UsersTable extends AbstractTable<UsersTable> {
4
+ id: import("../../columns/column").Column<import("../../columns/types/pgSerial").default, true, true, this>;
5
+ fullName: import("../../columns/column").Column<import("../..").PgText, true, false, this>;
6
+ phone: import("../../columns/column").Column<import("../..").PgVarChar, true, false, this>;
7
+ media: import("../../columns/column").Column<import("../..").PgJsonb<string[]>, true, false, this>;
8
+ decimalField: import("../../columns/column").Column<import("../..").PgBigDecimal, false, false, this>;
9
+ bigIntField: import("../../columns/column").Column<import("../..").PgBigInt, true, false, this>;
10
+ role: import("../../columns/column").Column<import("../../columns/types/pgEnum").default<"foo" | "bar" | "baz">, false, false, this>;
11
+ createdAt: import("../../columns/column").Column<import("../..").PgTimestamp, false, false, this>;
12
+ updatedAt: import("../../columns/column").Column<import("../..").PgTimestamp, true, false, this>;
13
+ isArchived: import("../../columns/column").Column<import("../..").PgBoolean, true, false, this>;
14
+ phoneFullNameIndex: import("../../indexes/tableIndex").default;
15
+ phoneIndex: import("../../indexes/tableIndex").default;
16
+ tableName(): string;
17
+ }
@@ -0,0 +1,35 @@
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
+ exports.rolesEnum = void 0;
7
+ /* eslint-disable max-classes-per-file */
8
+ // import { Defaults } from '../../columns/column';
9
+ const column_1 = require("../../columns/column");
10
+ const abstractTable_1 = __importDefault(require("../../tables/abstractTable"));
11
+ const type_1 = require("../../types/type");
12
+ // import { rolesEnum } from '../types/rolesType';
13
+ exports.rolesEnum = type_1.createEnum({ alias: 'test-enum', values: ['foo', 'bar', 'baz'] });
14
+ class UsersTable extends abstractTable_1.default {
15
+ constructor() {
16
+ super(...arguments);
17
+ this.id = this.serial('id').primaryKey();
18
+ this.fullName = this.text('full_name');
19
+ this.phone = this.varchar('phone', { size: 256 });
20
+ this.media = this.jsonb('media');
21
+ this.decimalField = this.decimal('test', { precision: 100, scale: 2 }).notNull();
22
+ this.bigIntField = this.bigint('test1', 'max_bytes_53');
23
+ this.role = this.type(exports.rolesEnum, 'name_in_table').notNull();
24
+ this.createdAt = this.timestamp('created_at').notNull();
25
+ // public createdAtWithTimezone = this.timestamptz('created_at');
26
+ this.updatedAt = this.timestamp('updated_at').defaultValue(column_1.Defaults.CURRENT_TIMESTAMP);
27
+ this.isArchived = this.bool('is_archived').defaultValue(false);
28
+ this.phoneFullNameIndex = this.index([this.phone, this.fullName]);
29
+ this.phoneIndex = this.uniqueIndex(this.phone);
30
+ }
31
+ tableName() {
32
+ return 'users';
33
+ }
34
+ }
35
+ exports.default = UsersTable;
@@ -0,0 +1,7 @@
1
+ import AbstractTable from '../../tables/abstractTable';
2
+ export default class UsersToUserGroupsTable extends AbstractTable<UsersToUserGroupsTable> {
3
+ groupId: import("../..").Column<import("../..").PgInteger, true, false, this>;
4
+ userId: import("../..").Column<import("../..").PgInteger, true, false, this>;
5
+ manyToManyIndex: import("../../indexes/tableIndex").default;
6
+ tableName(): string;
7
+ }
@@ -0,0 +1,20 @@
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 abstractTable_1 = __importDefault(require("../../tables/abstractTable"));
7
+ const userGroupsTable_1 = __importDefault(require("./userGroupsTable"));
8
+ const usersTable_1 = __importDefault(require("./usersTable"));
9
+ class UsersToUserGroupsTable extends abstractTable_1.default {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.groupId = this.int('city_id').foreignKey(userGroupsTable_1.default, (table) => table.id, { onDelete: 'CASCADE' });
13
+ this.userId = this.int('user_id').foreignKey(usersTable_1.default, (table) => table.id, { onDelete: 'CASCADE' });
14
+ this.manyToManyIndex = this.index([this.groupId, this.userId]);
15
+ }
16
+ tableName() {
17
+ return 'users_to_user_groups';
18
+ }
19
+ }
20
+ exports.default = UsersToUserGroupsTable;
@@ -0,0 +1 @@
1
+ export declare const rolesEnum: import("../../types/type").default<"foo" | "bar" | "baz">;
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.rolesEnum = void 0;
4
+ const type_1 = require("../../types/type");
5
+ // eslint-disable-next-line import/prefer-default-export
6
+ exports.rolesEnum = type_1.createEnum({ alias: 'test-enum', values: ['foo', 'bar', 'baz'] });
@@ -0,0 +1,22 @@
1
+ export interface Failure {
2
+ type: PgSessionError;
3
+ reason: Error;
4
+ }
5
+ export declare enum PgSessionError {
6
+ PgQueryExecutionError = 0
7
+ }
8
+ export declare type Either<L, A> = Left<L, A> | Right<L, A>;
9
+ export declare class Left<L, A> {
10
+ readonly value: L;
11
+ constructor(value: L);
12
+ isLeft(): this is Left<L, A>;
13
+ isRight(): this is Right<L, A>;
14
+ }
15
+ export declare class Right<L, A> {
16
+ readonly value: A;
17
+ constructor(value: A);
18
+ isLeft(): this is Left<L, A>;
19
+ isRight(): this is Right<L, A>;
20
+ }
21
+ export declare const left: <L, A>(l: L) => Either<L, A>;
22
+ export declare const right: <L, A>(a: A) => Either<L, A>;
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.right = exports.left = exports.Right = exports.Left = exports.PgSessionError = void 0;
4
+ var PgSessionError;
5
+ (function (PgSessionError) {
6
+ PgSessionError[PgSessionError["PgQueryExecutionError"] = 0] = "PgQueryExecutionError";
7
+ })(PgSessionError = exports.PgSessionError || (exports.PgSessionError = {}));
8
+ class Left {
9
+ constructor(value) {
10
+ this.value = value;
11
+ }
12
+ isLeft() {
13
+ return true;
14
+ }
15
+ isRight() {
16
+ return false;
17
+ }
18
+ }
19
+ exports.Left = Left;
20
+ class Right {
21
+ constructor(value) {
22
+ this.value = value;
23
+ }
24
+ isLeft() {
25
+ return false;
26
+ }
27
+ isRight() {
28
+ return true;
29
+ }
30
+ }
31
+ exports.Right = Right;
32
+ const left = (l) => new Left(l);
33
+ exports.left = left;
34
+ const right = (a) => new Right(a);
35
+ exports.right = right;
@@ -0,0 +1,14 @@
1
+ import Expr from '../builders/requestBuilders/where/where';
2
+ import { AbstractColumn } from '../columns/column';
3
+ import ColumnType from '../columns/types/columnType';
4
+ export declare enum BuilderType {
5
+ SELECT = 0,
6
+ JOINED_SELECT = 1,
7
+ TWO_JOINED_SELECT = 2,
8
+ DELETE = 3,
9
+ INSERT = 4,
10
+ UPDATE = 5
11
+ }
12
+ export default class BuilderError extends Error {
13
+ constructor(builderType: BuilderType, tableName: string, columns: AbstractColumn<ColumnType>[], reason: Error, filter?: Expr);
14
+ }
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BuilderType = void 0;
4
+ var BuilderType;
5
+ (function (BuilderType) {
6
+ BuilderType[BuilderType["SELECT"] = 0] = "SELECT";
7
+ BuilderType[BuilderType["JOINED_SELECT"] = 1] = "JOINED_SELECT";
8
+ BuilderType[BuilderType["TWO_JOINED_SELECT"] = 2] = "TWO_JOINED_SELECT";
9
+ BuilderType[BuilderType["DELETE"] = 3] = "DELETE";
10
+ BuilderType[BuilderType["INSERT"] = 4] = "INSERT";
11
+ BuilderType[BuilderType["UPDATE"] = 5] = "UPDATE";
12
+ })(BuilderType = exports.BuilderType || (exports.BuilderType = {}));
13
+ class BuilderError extends Error {
14
+ constructor(builderType, tableName, columns, reason, filter) {
15
+ super('');
16
+ this.message = ` Error while building select query from ${tableName}\n-----\nIf you see current error, please create [github issue](https://github.com/lambda-direct/drizzle-orm/issues) and provide following information\n
17
+ Reason: ${reason.message}
18
+ Query builder: ${BuilderType[builderType]}
19
+ Table name: ${tableName}
20
+ Filter query: ${filter ? filter.toQuery().query : 'undefined'}
21
+ Values: ${filter ? filter.toQuery().values : 'undefined'}
22
+ Column names: ${columns.map((column) => column.getColumnName()).join(', ')}\n-----\n`;
23
+ }
24
+ }
25
+ exports.default = BuilderError;
@@ -0,0 +1,12 @@
1
+ export declare class DatabaseSelectError extends Error {
2
+ constructor(tableName: string, reason: Error, query: string);
3
+ }
4
+ export declare class DatabaseDeleteError extends Error {
5
+ constructor(tableName: string, reason: Error, query: string);
6
+ }
7
+ export declare class DatabaseInsertError extends Error {
8
+ constructor(tableName: string, reason: Error, query: string);
9
+ }
10
+ export declare class DatabaseUpdateError extends Error {
11
+ constructor(tableName: string, reason: Error, query: string);
12
+ }
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DatabaseUpdateError = exports.DatabaseInsertError = exports.DatabaseDeleteError = exports.DatabaseSelectError = void 0;
4
+ /* eslint-disable max-classes-per-file */
5
+ class DatabaseSelectError extends Error {
6
+ constructor(tableName, reason, query) {
7
+ super(` Got an error, while selecting from ${tableName}. Reason: ${reason.message}. Query to database looks like:\n${query}\n`);
8
+ }
9
+ }
10
+ exports.DatabaseSelectError = DatabaseSelectError;
11
+ class DatabaseDeleteError extends Error {
12
+ constructor(tableName, reason, query) {
13
+ super(` Got an error, while deleting from ${tableName}. Reason: ${reason.message}. Query to database looks like:\n${query}\n`);
14
+ }
15
+ }
16
+ exports.DatabaseDeleteError = DatabaseDeleteError;
17
+ class DatabaseInsertError extends Error {
18
+ constructor(tableName, reason, query) {
19
+ super(` Got an error, while inserting to ${tableName}. Reason: ${reason.message}. Query to database looks like:\n${query}\n`);
20
+ }
21
+ }
22
+ exports.DatabaseInsertError = DatabaseInsertError;
23
+ class DatabaseUpdateError extends Error {
24
+ constructor(tableName, reason, query) {
25
+ super(` Got an error, while updating ${tableName}. Reason: ${reason.message}. Query to database looks like:\n${query}\n`);
26
+ }
27
+ }
28
+ exports.DatabaseUpdateError = DatabaseUpdateError;
@@ -0,0 +1,11 @@
1
+ import { ClientConfig } from 'pg';
2
+ import { DB } from './db';
3
+ import Migrator from './migrator/migrator';
4
+ export * from './db';
5
+ export * from './builders';
6
+ export * from './columns';
7
+ export * from './tables';
8
+ export declare const drizzle: {
9
+ connect(config: ClientConfig): Promise<DB>;
10
+ migrator(db: DB): Migrator;
11
+ };
@@ -0,0 +1,31 @@
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
+ };
12
+ var __importDefault = (this && this.__importDefault) || function (mod) {
13
+ return (mod && mod.__esModule) ? mod : { "default": mod };
14
+ };
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.drizzle = void 0;
17
+ const db_1 = require("./db");
18
+ const migrator_1 = __importDefault(require("./migrator/migrator"));
19
+ __exportStar(require("./db"), exports);
20
+ __exportStar(require("./builders"), exports);
21
+ __exportStar(require("./columns"), exports);
22
+ __exportStar(require("./tables"), exports);
23
+ exports.drizzle = {
24
+ async connect(config) {
25
+ const dbConnector = new db_1.DbConnector().params(config);
26
+ return dbConnector.connect();
27
+ },
28
+ migrator(db) {
29
+ return new migrator_1.default(db);
30
+ },
31
+ };
@@ -0,0 +1,11 @@
1
+ import { Column } from '../columns/column';
2
+ import ColumnType from '../columns/types/columnType';
3
+ export default class TableIndex {
4
+ private _columns;
5
+ private _tableName;
6
+ private _isUnique;
7
+ constructor(tableName: string, columns: Column<ColumnType<any>, boolean, boolean>[], isUnique?: boolean);
8
+ getColumns: () => Column<ColumnType<any>, boolean, boolean>[];
9
+ indexName: () => string;
10
+ isUnique: () => boolean;
11
+ }
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ class TableIndex {
4
+ constructor(tableName, columns, isUnique = false) {
5
+ this._columns = [];
6
+ this.getColumns = () => this._columns;
7
+ this.indexName = () => {
8
+ const columnNames = this._columns.map((column) => column.getColumnName());
9
+ return `${this._tableName}_${columnNames.join('_')}_index`;
10
+ };
11
+ this.isUnique = () => this._isUnique;
12
+ this._columns = columns;
13
+ this._tableName = tableName;
14
+ this._isUnique = isUnique;
15
+ }
16
+ }
17
+ exports.default = TableIndex;
@@ -0,0 +1,4 @@
1
+ export default abstract class BaseLogger {
2
+ abstract info(msg: string): void;
3
+ abstract error(msg: string): void;
4
+ }
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ class BaseLogger {
4
+ }
5
+ exports.default = BaseLogger;
@@ -0,0 +1,5 @@
1
+ import BaseLogger from './abstractLogger';
2
+ export default class ConsoleLogger extends BaseLogger {
3
+ info(msg: string): void;
4
+ error(msg: string): void;
5
+ }
@@ -0,0 +1,15 @@
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 abstractLogger_1 = __importDefault(require("./abstractLogger"));
7
+ class ConsoleLogger extends abstractLogger_1.default {
8
+ info(msg) {
9
+ console.log(`INFO: ${msg}`);
10
+ }
11
+ error(msg) {
12
+ console.log(`ERROR: ${msg}`);
13
+ }
14
+ }
15
+ exports.default = ConsoleLogger;
File without changes
@@ -0,0 +1 @@
1
+ "use strict";