midway-fatcms 0.0.1-beta.4 → 0.0.1-beta.40

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 (331) hide show
  1. package/.eslintrc.json +14 -0
  2. package/.prettierrc.js +4 -0
  3. package/README.md +7 -0
  4. package/dist/config/config.default.js +58 -15
  5. package/dist/config/seed/aeskey.txt +1 -1
  6. package/dist/configuration.d.ts +1 -0
  7. package/dist/configuration.js +33 -9
  8. package/dist/controller/base/BaseApiController.d.ts +7 -1
  9. package/dist/controller/base/BaseApiController.js +32 -6
  10. package/dist/controller/gateway/AsyncTaskController.d.ts +20 -0
  11. package/dist/controller/gateway/AsyncTaskController.js +181 -0
  12. package/dist/controller/gateway/CrudMtdGatewayController.d.ts +3 -3
  13. package/dist/controller/gateway/CrudMtdGatewayController.js +9 -6
  14. package/dist/controller/gateway/DocGatewayController.js +14 -9
  15. package/dist/controller/gateway/FileController.d.ts +3 -2
  16. package/dist/controller/gateway/PublicApiController.js +4 -6
  17. package/dist/controller/gateway/StaticController.d.ts +0 -1
  18. package/dist/controller/gateway/StaticController.js +40 -39
  19. package/dist/controller/helpers.controller.d.ts +1 -1
  20. package/dist/controller/home.controller.js +4 -3
  21. package/dist/controller/manage/AnyApiMangeApi.js +2 -2
  22. package/dist/controller/manage/AppLogMangeApi.js +2 -2
  23. package/dist/controller/manage/AppMangeApi.js +2 -2
  24. package/dist/controller/manage/AppPageMangeApi.js +2 -2
  25. package/dist/controller/manage/AppSchemaHistoryApi.js +2 -2
  26. package/dist/controller/manage/CrudMethodsMangeApi.js +2 -2
  27. package/dist/controller/manage/CrudStandardDesignApi.d.ts +1 -1
  28. package/dist/controller/manage/CrudStandardDesignApi.js +86 -83
  29. package/dist/controller/manage/DataDictManageApi.d.ts +1 -1
  30. package/dist/controller/manage/DataDictManageApi.js +1 -1
  31. package/dist/controller/manage/DeployManageApi.d.ts +1 -1
  32. package/dist/controller/manage/DeployManageApi.js +38 -34
  33. package/dist/controller/manage/DocLibManageApi.js +2 -2
  34. package/dist/controller/manage/DocManageApi.js +2 -2
  35. package/dist/controller/manage/FileManageApi.js +1 -1
  36. package/dist/controller/manage/LowCodeTplManageApi.js +2 -2
  37. package/dist/controller/manage/MenuManageApi.js +2 -2
  38. package/dist/controller/manage/ProxyApiMangeApi.js +2 -2
  39. package/dist/controller/manage/SuperAdminManageApi.d.ts +2 -2
  40. package/dist/controller/manage/SuperAdminManageApi.js +12 -8
  41. package/dist/controller/manage/SysConfigMangeApi.d.ts +1 -1
  42. package/dist/controller/manage/SysConfigMangeApi.js +8 -6
  43. package/dist/controller/manage/SystemInfoManageApi.d.ts +1 -1
  44. package/dist/controller/manage/SystemInfoManageApi.js +7 -1
  45. package/dist/controller/manage/UserAccountManageApi.d.ts +2 -2
  46. package/dist/controller/manage/UserAccountManageApi.js +7 -2
  47. package/dist/controller/manage/WorkbenchMangeApi.js +3 -3
  48. package/dist/controller/myinfo/AuthController.d.ts +0 -4
  49. package/dist/controller/myinfo/AuthController.js +1 -54
  50. package/dist/controller/render/AppRenderController.js +12 -5
  51. package/dist/controller/test.controller.d.ts +1 -1
  52. package/dist/controller/test.controller.js +5 -5
  53. package/dist/index.d.ts +35 -4
  54. package/dist/index.js +35 -4
  55. package/dist/libs/crud-pro/CrudPro.d.ts +1 -0
  56. package/dist/libs/crud-pro/CrudPro.js +5 -0
  57. package/dist/libs/crud-pro/defaultConfigs.js +2 -0
  58. package/dist/libs/crud-pro/interfaces.d.ts +7 -1
  59. package/dist/libs/crud-pro/models/ExecuteContext.d.ts +12 -5
  60. package/dist/libs/crud-pro/models/ExecuteContextFunc.d.ts +8 -1
  61. package/dist/libs/crud-pro/models/ExecuteContextFunc.js +8 -0
  62. package/dist/libs/crud-pro/models/RequestCfgModel.d.ts +1 -1
  63. package/dist/libs/crud-pro/models/ResModel.d.ts +16 -0
  64. package/dist/libs/crud-pro/models/ResModel.js +2 -0
  65. package/dist/libs/crud-pro/models/SqlCfgModel.d.ts +1 -1
  66. package/dist/libs/crud-pro/models/TransactionSqlServer.js +1 -1
  67. package/dist/libs/crud-pro/services/CrudProCachedCfgService.d.ts +1 -0
  68. package/dist/libs/crud-pro/services/CrudProCachedCfgService.js +27 -15
  69. package/dist/libs/crud-pro/services/CrudProExecuteSqlService.js +17 -19
  70. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.d.ts +1 -1
  71. package/dist/libs/crud-pro/services/CrudProGenSqlCondition.js +10 -12
  72. package/dist/libs/crud-pro/services/CrudProGenSqlService.js +14 -23
  73. package/dist/libs/crud-pro/services/CrudProOriginToExecuteSql.js +7 -6
  74. package/dist/libs/crud-pro/services/CrudProServiceBase.d.ts +2 -6
  75. package/dist/libs/crud-pro/services/CrudProServiceBase.js +15 -3
  76. package/dist/libs/crud-pro/services/CrudProTableMetaService.d.ts +1 -0
  77. package/dist/libs/crud-pro/services/CrudProTableMetaService.js +32 -7
  78. package/dist/libs/crud-pro/sql.txt +120 -120
  79. package/dist/libs/crud-pro/utils/DatabaseName.js +24 -3
  80. package/dist/libs/crud-pro/utils/MixinUtils.js +1 -1
  81. package/dist/libs/crud-pro/utils/ValidateUtils.js +1 -1
  82. package/dist/libs/crud-pro/utils/sqlConvert/convertColumnName.js +2 -2
  83. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.d.ts +3 -0
  84. package/dist/libs/crud-pro/utils/sqlConvert/convertMix.js +22 -0
  85. package/dist/libs/global-config/global-config.d.ts +45 -0
  86. package/dist/libs/global-config/global-config.js +33 -0
  87. package/dist/libs/utils/errorToString.d.ts +2 -0
  88. package/dist/libs/utils/errorToString.js +57 -0
  89. package/dist/libs/utils/fatcms-request.js +2 -2
  90. package/dist/libs/utils/functions.d.ts +2 -1
  91. package/dist/libs/utils/functions.js +6 -1
  92. package/dist/middleware/forbidden.middleware.js +4 -20
  93. package/dist/middleware/global.middleware.js +30 -10
  94. package/dist/middleware/permission.middleware.js +1 -1
  95. package/dist/models/AsyncTaskModel.d.ts +74 -0
  96. package/dist/models/AsyncTaskModel.js +31 -0
  97. package/dist/models/RedisKeys.d.ts +14 -0
  98. package/dist/models/RedisKeys.js +17 -0
  99. package/dist/models/SystemEntities.d.ts +8 -1
  100. package/dist/models/SystemEntities.js +7 -0
  101. package/dist/models/SystemTables.d.ts +1 -3
  102. package/dist/models/SystemTables.js +2 -4
  103. package/dist/models/bizmodels.d.ts +28 -0
  104. package/dist/models/bizmodels.js +6 -1
  105. package/dist/schedule/anonymousContext.d.ts +14 -0
  106. package/dist/schedule/anonymousContext.js +59 -0
  107. package/dist/schedule/index.d.ts +4 -3
  108. package/dist/schedule/index.js +8 -67
  109. package/dist/schedule/runSchedule.d.ts +12 -0
  110. package/dist/schedule/runSchedule.js +68 -0
  111. package/dist/schedule/scheduleNames.d.ts +13 -0
  112. package/dist/schedule/scheduleNames.js +17 -0
  113. package/dist/service/AuthService.js +8 -5
  114. package/dist/service/EnumInfoService.js +9 -5
  115. package/dist/service/FileCenterService.js +13 -9
  116. package/dist/service/SysConfigService.d.ts +1 -1
  117. package/dist/service/SysConfigService.js +4 -2
  118. package/dist/service/UserAccountService.js +10 -6
  119. package/dist/service/UserSessionService.d.ts +21 -0
  120. package/dist/service/UserSessionService.js +73 -2
  121. package/dist/service/VisitStatService.d.ts +1 -1
  122. package/dist/service/VisitStatService.js +20 -27
  123. package/dist/service/WorkbenchService.d.ts +33 -0
  124. package/dist/service/WorkbenchService.js +70 -12
  125. package/dist/service/anyapi/AnyApiSandboxService.js +12 -12
  126. package/dist/service/anyapi/AnyApiService.js +4 -2
  127. package/dist/service/asyncTask/AsyncTaskRunnerService.d.ts +50 -0
  128. package/dist/service/asyncTask/AsyncTaskRunnerService.js +287 -0
  129. package/dist/service/asyncTask/AsyncTaskService.d.ts +7 -0
  130. package/dist/service/asyncTask/AsyncTaskService.js +34 -0
  131. package/dist/service/asyncTask/handler/ExcelInfoModel.d.ts +10 -0
  132. package/dist/service/asyncTask/handler/ExcelInfoModel.js +2 -0
  133. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.d.ts +7 -0
  134. package/dist/service/asyncTask/handler/ExportExcelAsyncTaskHandler.js +216 -0
  135. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.d.ts +36 -0
  136. package/dist/service/asyncTask/handler/ExportExcelByInnerHttpHandler.js +139 -0
  137. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.d.ts +46 -0
  138. package/dist/service/asyncTask/handler/ExportExcelByStdCrudHandler.js +121 -0
  139. package/dist/service/base/BaseService.d.ts +12 -0
  140. package/dist/service/base/BaseService.js +22 -0
  141. package/dist/service/base/RedisCacheService.d.ts +7 -0
  142. package/dist/service/base/RedisCacheService.js +7 -0
  143. package/dist/service/crudstd/CrudStdService.d.ts +8 -1
  144. package/dist/service/crudstd/CrudStdService.js +63 -6
  145. package/dist/service/curd/CrudProQuick.d.ts +44 -0
  146. package/dist/service/curd/CrudProQuick.js +147 -0
  147. package/dist/service/curd/CurdMixByAccountService.d.ts +4 -4
  148. package/dist/service/curd/CurdMixByAccountService.js +12 -6
  149. package/dist/service/curd/CurdMixByDictService.d.ts +4 -4
  150. package/dist/service/curd/CurdMixByDictService.js +10 -7
  151. package/dist/service/curd/CurdMixByLinkToCustomService.d.ts +13 -4
  152. package/dist/service/curd/CurdMixByLinkToCustomService.js +73 -24
  153. package/dist/service/curd/CurdMixBySysConfigService.d.ts +3 -3
  154. package/dist/service/curd/CurdMixBySysConfigService.js +4 -2
  155. package/dist/service/curd/CurdMixByWorkbenchService.d.ts +3 -3
  156. package/dist/service/curd/CurdMixByWorkbenchService.js +4 -2
  157. package/dist/service/curd/CurdMixService.d.ts +13 -3
  158. package/dist/service/curd/CurdMixService.js +26 -2
  159. package/dist/service/curd/CurdMixUtils.d.ts +27 -4
  160. package/dist/service/curd/CurdMixUtils.js +115 -41
  161. package/dist/service/curd/CurdProService.d.ts +3 -10
  162. package/dist/service/curd/CurdProService.js +36 -148
  163. package/dist/service/curd/fixCfgModel.d.ts +3 -0
  164. package/dist/service/curd/fixCfgModel.js +107 -0
  165. package/dist/service/proxyapi/ProxyApiLoadService.js +7 -4
  166. package/dist/service/proxyapi/ProxyApiService.js +28 -7
  167. package/dist/views/404_app.html +31 -31
  168. package/dist/views/404_workbench.html +34 -34
  169. package/package.json +25 -24
  170. package/tsconfig.json +32 -0
  171. package/dist/controller/medstatistic/MedAdminController.d.ts +0 -35
  172. package/dist/controller/medstatistic/MedAdminController.js +0 -205
  173. package/dist/controller/medstatistic/MedClientController.d.ts +0 -28
  174. package/dist/controller/medstatistic/MedClientController.js +0 -188
  175. package/dist/controller/medstatistic/MedMessageService.d.ts +0 -19
  176. package/dist/controller/medstatistic/MedMessageService.js +0 -95
  177. package/dist/controller/medstatistic/MedScoreService.d.ts +0 -21
  178. package/dist/controller/medstatistic/MedScoreService.js +0 -107
  179. package/dist/controller/medstatistic/constants.d.ts +0 -32
  180. package/dist/controller/medstatistic/constants.js +0 -43
  181. package/src/config/config.default.ts +0 -172
  182. package/src/config/seed/aeskey.txt +0 -1
  183. package/src/config/utils.ts +0 -23
  184. package/src/configuration.ts +0 -83
  185. package/src/controller/base/BaseApiController.ts +0 -145
  186. package/src/controller/gateway/AnyApiGatewayController.ts +0 -33
  187. package/src/controller/gateway/CrudMtdGatewayController.ts +0 -107
  188. package/src/controller/gateway/CrudStdGatewayController.ts +0 -101
  189. package/src/controller/gateway/DocGatewayController.ts +0 -165
  190. package/src/controller/gateway/FileController.ts +0 -110
  191. package/src/controller/gateway/ProxyApiGatewayController.ts +0 -47
  192. package/src/controller/gateway/PublicApiController.ts +0 -145
  193. package/src/controller/gateway/StaticController.ts +0 -328
  194. package/src/controller/helpers.controller.ts +0 -161
  195. package/src/controller/home.controller.ts +0 -71
  196. package/src/controller/manage/AnyApiMangeApi.ts +0 -66
  197. package/src/controller/manage/AppLogMangeApi.ts +0 -53
  198. package/src/controller/manage/AppMangeApi.ts +0 -53
  199. package/src/controller/manage/AppPageMangeApi.ts +0 -52
  200. package/src/controller/manage/AppSchemaHistoryApi.ts +0 -49
  201. package/src/controller/manage/CrudMethodsMangeApi.ts +0 -49
  202. package/src/controller/manage/CrudStandardDesignApi.ts +0 -353
  203. package/src/controller/manage/DataDictManageApi.ts +0 -78
  204. package/src/controller/manage/DeployManageApi.ts +0 -179
  205. package/src/controller/manage/DocLibManageApi.ts +0 -69
  206. package/src/controller/manage/DocManageApi.ts +0 -99
  207. package/src/controller/manage/FileManageApi.ts +0 -45
  208. package/src/controller/manage/LowCodeTplManageApi.ts +0 -52
  209. package/src/controller/manage/MenuManageApi.ts +0 -63
  210. package/src/controller/manage/ProxyApiMangeApi.ts +0 -52
  211. package/src/controller/manage/SuperAdminManageApi.ts +0 -138
  212. package/src/controller/manage/SysConfigMangeApi.ts +0 -95
  213. package/src/controller/manage/SystemInfoManageApi.ts +0 -48
  214. package/src/controller/manage/UserAccountManageApi.ts +0 -88
  215. package/src/controller/manage/WorkbenchMangeApi.ts +0 -72
  216. package/src/controller/medstatistic/MedAdminController.ts +0 -221
  217. package/src/controller/medstatistic/MedClientController.ts +0 -188
  218. package/src/controller/medstatistic/MedMessageService.ts +0 -89
  219. package/src/controller/medstatistic/MedScoreService.ts +0 -108
  220. package/src/controller/medstatistic/constants.ts +0 -63
  221. package/src/controller/myinfo/AuthController.ts +0 -174
  222. package/src/controller/myinfo/MyInfoController.ts +0 -32
  223. package/src/controller/render/AppRenderController.ts +0 -76
  224. package/src/controller/test.controller.ts +0 -37
  225. package/src/filter/default.filter.ts +0 -13
  226. package/src/filter/notfound.filter.ts +0 -10
  227. package/src/index.ts +0 -71
  228. package/src/interface.ts +0 -31
  229. package/src/libs/crud-pro/CrudPro.ts +0 -158
  230. package/src/libs/crud-pro/defaultConfigs.ts +0 -13
  231. package/src/libs/crud-pro/exceptions.ts +0 -124
  232. package/src/libs/crud-pro/interfaces.ts +0 -183
  233. package/src/libs/crud-pro/models/ExecuteContext.ts +0 -111
  234. package/src/libs/crud-pro/models/ExecuteContextFunc.ts +0 -86
  235. package/src/libs/crud-pro/models/FuncContext.ts +0 -21
  236. package/src/libs/crud-pro/models/RequestCfgModel.ts +0 -141
  237. package/src/libs/crud-pro/models/RequestModel.ts +0 -141
  238. package/src/libs/crud-pro/models/ServiceHub.ts +0 -32
  239. package/src/libs/crud-pro/models/SqlCfgModel.ts +0 -52
  240. package/src/libs/crud-pro/models/SqlSegArg.ts +0 -13
  241. package/src/libs/crud-pro/models/Transaction.ts +0 -74
  242. package/src/libs/crud-pro/models/TransactionMySQL.ts +0 -79
  243. package/src/libs/crud-pro/models/TransactionPostgres.ts +0 -91
  244. package/src/libs/crud-pro/models/TransactionSqlServer.ts +0 -107
  245. package/src/libs/crud-pro/models/keys.ts +0 -159
  246. package/src/libs/crud-pro/services/CrudProCachedCfgService.ts +0 -75
  247. package/src/libs/crud-pro/services/CrudProExecuteFuncService.ts +0 -128
  248. package/src/libs/crud-pro/services/CrudProExecuteSqlService.ts +0 -279
  249. package/src/libs/crud-pro/services/CrudProFieldUpdateService.ts +0 -60
  250. package/src/libs/crud-pro/services/CrudProFieldValidateService.ts +0 -180
  251. package/src/libs/crud-pro/services/CrudProGenSqlCondition.ts +0 -373
  252. package/src/libs/crud-pro/services/CrudProGenSqlService.ts +0 -202
  253. package/src/libs/crud-pro/services/CrudProOriginToExecuteSql.ts +0 -397
  254. package/src/libs/crud-pro/services/CrudProServiceBase.ts +0 -98
  255. package/src/libs/crud-pro/services/CrudProTableMetaService.ts +0 -59
  256. package/src/libs/crud-pro/services/CurdProServiceHub.ts +0 -92
  257. package/src/libs/crud-pro/sql.txt +0 -120
  258. package/src/libs/crud-pro/utils/CompareUtils.ts +0 -23
  259. package/src/libs/crud-pro/utils/DatabaseName.ts +0 -40
  260. package/src/libs/crud-pro/utils/DateTimeUtils.ts +0 -20
  261. package/src/libs/crud-pro/utils/MemoryRefreshCache.ts +0 -64
  262. package/src/libs/crud-pro/utils/MessageParseUtils.ts +0 -33
  263. package/src/libs/crud-pro/utils/MixinUtils.ts +0 -285
  264. package/src/libs/crud-pro/utils/ModelUtils.ts +0 -55
  265. package/src/libs/crud-pro/utils/MultiKeyMap.ts +0 -72
  266. package/src/libs/crud-pro/utils/SqlFuncUtils.ts +0 -29
  267. package/src/libs/crud-pro/utils/TypeUtils.ts +0 -188
  268. package/src/libs/crud-pro/utils/ValidateUtils.ts +0 -167
  269. package/src/libs/crud-pro/utils/pool/MySQLUtils.ts +0 -20
  270. package/src/libs/crud-pro/utils/pool/PostgresUtils.ts +0 -22
  271. package/src/libs/crud-pro/utils/pool/SqlServerUtils.ts +0 -22
  272. package/src/libs/crud-pro/utils/sqlConvert/convertColumnName.ts +0 -26
  273. package/src/libs/crud-pro/utils/sqlConvert/convertMsSql.ts +0 -11
  274. package/src/libs/crud-pro/utils/sqlConvert/convertPgSql.ts +0 -11
  275. package/src/libs/crud-pro/utils/sqlConvert/convertPgType.ts +0 -129
  276. package/src/libs/utils/common-dto.ts +0 -52
  277. package/src/libs/utils/crypto-utils.ts +0 -52
  278. package/src/libs/utils/fatcms-request.ts +0 -115
  279. package/src/libs/utils/functions.ts +0 -67
  280. package/src/libs/utils/ordernum-utils.ts +0 -18
  281. package/src/libs/utils/parseConfig.ts +0 -62
  282. package/src/libs/utils/parseCreateSql.ts +0 -91
  283. package/src/libs/utils/render-utils.ts +0 -184
  284. package/src/middleware/forbidden.middleware.ts +0 -71
  285. package/src/middleware/global.middleware.ts +0 -278
  286. package/src/middleware/permission.middleware.ts +0 -81
  287. package/src/middleware/tx.middleware.ts +0 -30
  288. package/src/models/SystemEntities.ts +0 -115
  289. package/src/models/SystemPerm.ts +0 -105
  290. package/src/models/SystemTables.ts +0 -30
  291. package/src/models/bizmodels.ts +0 -89
  292. package/src/models/contextLogger.ts +0 -132
  293. package/src/models/devops.ts +0 -17
  294. package/src/models/userSession.ts +0 -216
  295. package/src/schedule/index.ts +0 -73
  296. package/src/service/AuthService.ts +0 -270
  297. package/src/service/EnumInfoService.ts +0 -129
  298. package/src/service/FileCenterService.ts +0 -394
  299. package/src/service/SysConfigService.ts +0 -34
  300. package/src/service/UserAccountService.ts +0 -100
  301. package/src/service/UserSessionService.ts +0 -81
  302. package/src/service/VisitStatService.ts +0 -179
  303. package/src/service/WorkbenchService.ts +0 -160
  304. package/src/service/anyapi/AnyApiSandboxService.ts +0 -121
  305. package/src/service/anyapi/AnyApiService.ts +0 -184
  306. package/src/service/base/ApiBaseService.ts +0 -42
  307. package/src/service/base/ApiRateLimiter.ts +0 -59
  308. package/src/service/base/BaseService.ts +0 -74
  309. package/src/service/base/RedisCacheService.ts +0 -38
  310. package/src/service/crudstd/CrudStdActionService.ts +0 -27
  311. package/src/service/crudstd/CrudStdConstant.ts +0 -62
  312. package/src/service/crudstd/CrudStdRelationService.ts +0 -78
  313. package/src/service/crudstd/CrudStdService.ts +0 -188
  314. package/src/service/curd/CurdMixByAccountService.ts +0 -83
  315. package/src/service/curd/CurdMixByDictService.ts +0 -113
  316. package/src/service/curd/CurdMixByLinkToCustomService.ts +0 -167
  317. package/src/service/curd/CurdMixBySysConfigService.ts +0 -78
  318. package/src/service/curd/CurdMixByWorkbenchService.ts +0 -68
  319. package/src/service/curd/CurdMixService.ts +0 -65
  320. package/src/service/curd/CurdMixUtils.ts +0 -248
  321. package/src/service/curd/CurdProService.ts +0 -379
  322. package/src/service/proxyapi/ProxyApiLoadService.ts +0 -165
  323. package/src/service/proxyapi/ProxyApiService.ts +0 -262
  324. package/src/service/proxyapi/ProxyApiUtils.ts +0 -32
  325. package/src/service/proxyapi/RouteHandler.ts +0 -8
  326. package/src/service/proxyapi/RouteTrie.ts +0 -74
  327. package/src/service/proxyapi/WeightedRandom.ts +0 -37
  328. package/src/service/proxyapi/WeightedRoundRobin.ts +0 -44
  329. package/src/views/404_app.html +0 -31
  330. package/src/views/404_workbench.html +0 -34
  331. package/src/views/static/favicon.ico +0 -0
@@ -1,373 +0,0 @@
1
- import {SqlSegArg} from '../models/SqlSegArg';
2
- import {MixinUtils} from '../utils/MixinUtils';
3
- import {KeysOfConditions, SqlDbType} from '../models/keys';
4
- import {CommonException, Exceptions} from '../exceptions';
5
- import {ICompareCondition, IRequestCondition} from '../interfaces';
6
- import {TypeUtils} from '../utils/TypeUtils';
7
- import {SqlCfgModel} from "../models/SqlCfgModel";
8
- import {toSqlColumnName} from '../utils/sqlConvert/convertColumnName';
9
-
10
- const { equalsIgnoreCase, isEmpty, isNotEmpty } = MixinUtils;
11
- const { isBasicType, isNumber } = TypeUtils;
12
-
13
- const createFunc = (sqlCfg: SqlCfgModel) => {
14
- return {
15
- toSqlColumnName: (columnName: string): string => {
16
- return toSqlColumnName(columnName, sqlCfg)
17
- },
18
- toMatchSqlColumnName: (columnName: string): string => {
19
- const arr = columnName.split(',');
20
- return arr
21
- .map(s => toSqlColumnName(s.trim(), sqlCfg))
22
- .join(',');
23
- }
24
- }
25
- }
26
-
27
- class ValueChecker {
28
- checkBasicArrayAndNotEmpty(value0: any, message: string) {
29
- // 不能为空
30
- if (!value0 || !Array.isArray(value0) || value0.length === 0) {
31
- throw new CommonException(Exceptions.REQUEST_PARAM_ERROR, message);
32
- }
33
-
34
- // 元素必须是基本数据类型
35
- for (let i = 0; i < value0.length; i++) {
36
- const value0Element = value0[i];
37
- if (!TypeUtils.isBasicType(value0Element)) {
38
- throw new CommonException(Exceptions.REQUEST_PARAM_ERROR, message);
39
- }
40
- }
41
- }
42
- }
43
-
44
- function hasCompareKey(compare: string): boolean {
45
- return KeysOfConditions.COMPARE_KEYS.has(compare);
46
- }
47
-
48
- const valueChecker = new ValueChecker();
49
-
50
- class CrudProGenSqlCondition {
51
- private readonly sqlCfg: SqlCfgModel;
52
- constructor(sqlCfg: SqlCfgModel) {
53
- this.sqlCfg = sqlCfg;
54
- }
55
-
56
- generateCondition(condition: any): SqlSegArg {
57
- if (isEmpty(condition)) {
58
- return new SqlSegArg(' 1=1 ');
59
- }
60
- const sqlArgModel = this.generateByLogicalKey(condition);
61
- const sql = ' 1=1 and ' + sqlArgModel.sql;
62
- return new SqlSegArg(sql, sqlArgModel.args);
63
- }
64
-
65
- /**
66
- * condition = {$or:[{name:'zhangsan'},{name:'lisi'},{age: {$gt:18}}],sex:1}
67
- * where (name = 'zhangsan' or name = 'lisi' or age > 18) and sex = 1
68
- * @param condition
69
- * @private
70
- */
71
- private generateByLogicalKey(condition: IRequestCondition): SqlSegArg {
72
- if (isEmpty(condition)) {
73
- return null;
74
- }
75
- const { toSqlColumnName } = createFunc(this.sqlCfg);
76
-
77
- const tmpSqlList = [];
78
- const tmpArgList = [];
79
-
80
- const keys = Object.keys(condition);
81
- for (let i = 0; i < keys.length; i++) {
82
- const key = keys[i];
83
- const value = condition[key];
84
-
85
- if (!hasCompareKey(key)) {
86
- // 第一层的key,不能是比较运算符。
87
- // OR
88
- if (equalsIgnoreCase(KeysOfConditions.$OR, key)) {
89
- TypeUtils.assertJsonArray(value, Exceptions.REQUEST_OR_PARAM_MUST_ARRAY);
90
-
91
- const a = this.generateByLogicalOR(value);
92
- if (a != null) {
93
- tmpSqlList.push(a.sql);
94
- if (isNotEmpty(a.args)) {
95
- tmpArgList.push(...a.args);
96
- }
97
- }
98
- }
99
-
100
- // AND
101
- else if (TypeUtils.isBasicType(value)) {
102
- tmpSqlList.push(toSqlColumnName(key) + '= ?');
103
- tmpArgList.push(value);
104
- } else {
105
- // AND
106
- const a = this.generateByCompareKey(key, value);
107
-
108
- if (a != null) {
109
- tmpSqlList.push(a.sql);
110
- if (MixinUtils.isNotEmpty(a.args)) {
111
- tmpArgList.push(...a.args);
112
- }
113
- }
114
- }
115
- }
116
- }
117
-
118
- if (isEmpty(tmpSqlList)) {
119
- return null;
120
- }
121
-
122
- // const sql = "(" + StringUtils.join(tmpSqlList, " AND ") + ")";
123
- const sql = '(' + tmpSqlList.join(' AND ') + ')';
124
- return new SqlSegArg(sql, tmpArgList);
125
- }
126
-
127
- private generateByLogicalOR(jsonArray: IRequestCondition[]): SqlSegArg {
128
- if (MixinUtils.isEmpty(jsonArray)) {
129
- return null;
130
- }
131
-
132
- const tmpSqlList = [];
133
- const tmpArgList = [];
134
-
135
- for (let i = 0; i < jsonArray.length; i++) {
136
- const jsonObject = jsonArray[i];
137
- const a = this.generateByLogicalKey(jsonObject);
138
- if (a != null) {
139
- tmpSqlList.push(a.sql);
140
- if (MixinUtils.isNotEmpty(a.args)) {
141
- tmpArgList.push(...a.args);
142
- }
143
- }
144
- }
145
- const sql = '(' + tmpSqlList.join(' OR ') + ')';
146
- return new SqlSegArg(sql, tmpArgList);
147
- }
148
-
149
- // 例如:
150
- // {name:1, age:{"$gt":5, "$lt":10}, } ==> name = 1 and (age > 5 and age < 10)
151
- // {name:1, age:{"$nin":[1,2,3],"$lt":10} } ==> name = 1 and (age not in (1,2,3) and age < 10)
152
- // 比较运算符
153
- private generateByCompareKey(key: string, map: ICompareCondition): SqlSegArg {
154
- if (isEmpty(map)) {
155
- return null;
156
- }
157
-
158
- const { toSqlColumnName, toMatchSqlColumnName } = createFunc(this.sqlCfg);
159
-
160
- this.generateByCompareKeyCheckParam(key, map);
161
-
162
- const tmpSqlList = [];
163
- const tmpArgList = [];
164
-
165
- let hasNoArgSql = false;
166
- const compareSet = Object.keys(map);
167
-
168
- for (let i = 0; i < compareSet.length; i++) {
169
- const compare = compareSet[i];
170
-
171
- if (hasCompareKey(compare)) {
172
- const value0 = map[compare];
173
-
174
- let tmpSql = '';
175
-
176
- if (equalsIgnoreCase(KeysOfConditions.$NULL, compare)) {
177
- tmpSql = `${toSqlColumnName(key)} is null `;
178
- hasNoArgSql = true;
179
- } else if (equalsIgnoreCase(KeysOfConditions.$NOT_NULL, compare)) {
180
- tmpSql = `${toSqlColumnName(key)} is not null `;
181
- hasNoArgSql = true;
182
- } else if (equalsIgnoreCase(KeysOfConditions.$GT, compare)) {
183
- tmpArgList.push(value0);
184
- tmpSql = `${toSqlColumnName(key)} > ?`;
185
- } else if (equalsIgnoreCase(KeysOfConditions.$GTE, compare)) {
186
- tmpArgList.push(value0);
187
- tmpSql = `${toSqlColumnName(key)} >= ?`;
188
- } else if (equalsIgnoreCase(KeysOfConditions.$LT, compare)) {
189
- tmpArgList.push(value0);
190
- tmpSql = `${toSqlColumnName(key)} < ?`;
191
- } else if (equalsIgnoreCase(KeysOfConditions.$LTE, compare)) {
192
- tmpArgList.push(value0);
193
- tmpSql = `${toSqlColumnName(key)} <= ?`;
194
- } else if (equalsIgnoreCase(KeysOfConditions.$NE, compare)) {
195
- tmpArgList.push(value0);
196
- tmpSql = `${toSqlColumnName(key)} != ?`;
197
- } else if (equalsIgnoreCase(KeysOfConditions.$IN, compare)) {
198
- const array = [...value0];
199
- if (isNotEmpty(array)) {
200
- const pm = array.map(() => '?').join(',');
201
- tmpSql = `${toSqlColumnName(key)} in (${pm})`;
202
- tmpArgList.push(...array);
203
- }
204
- } else if (equalsIgnoreCase(KeysOfConditions.$NIN, compare)) {
205
- const array = [...value0];
206
- if (isNotEmpty(array)) {
207
- const pm = array.map(() => '?').join(',');
208
- tmpSql = `${toSqlColumnName(key)} not in (${pm})`;
209
- tmpArgList.push(...array);
210
- }
211
- } else if (equalsIgnoreCase(KeysOfConditions.$LIKE, compare)) {
212
- tmpArgList.push(value0);
213
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI like concat(?, '%')`; // like前缀匹配
214
-
215
- if (this.sqlCfg.sqlDdType === SqlDbType.postgres) {
216
- tmpSql = `${toSqlColumnName(key)} like concat(?, '%')`; // like前缀匹配
217
- }
218
-
219
- } else if (equalsIgnoreCase(KeysOfConditions.$NOT_LIKE, compare)) {
220
- tmpArgList.push(value0);
221
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI not like concat(?, '%')`;
222
-
223
-
224
- if (this.sqlCfg.sqlDdType === SqlDbType.postgres) {
225
- tmpSql = `${toSqlColumnName(key)} not like concat(?, '%')`;
226
- }
227
-
228
- }
229
-
230
-
231
- else if (equalsIgnoreCase(KeysOfConditions.$LIKE_INCLUDE, compare)) {
232
- tmpArgList.push(value0);
233
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI like concat('%', ?, '%')`; // like包含
234
-
235
- if (this.sqlCfg.sqlDdType === SqlDbType.postgres) {
236
- tmpSql = `${toSqlColumnName(key)} like concat('%', ?, '%')`; // like包含
237
- }
238
-
239
- } else if (equalsIgnoreCase(KeysOfConditions.$NOT_LIKE_INCLUDE, compare)) {
240
- tmpArgList.push(value0);
241
- tmpSql = `${toSqlColumnName(key)} COLLATE UTF8MB4_GENERAL_CI not like concat('%',?, '%')`; // like不包含
242
-
243
- if (this.sqlCfg.sqlDdType === SqlDbType.postgres) {
244
- tmpSql = `${toSqlColumnName(key)} not like concat('%',?, '%')`; // like不包含
245
- }
246
-
247
- }
248
-
249
-
250
- else if (equalsIgnoreCase(KeysOfConditions.$MATCH, compare)) {
251
- tmpArgList.push(value0);
252
- tmpSql = `match(${toMatchSqlColumnName(key)}) against(?)`;
253
- } else if (equalsIgnoreCase(KeysOfConditions.$MATCH_BOOL, compare)) {
254
- tmpArgList.push(value0);
255
- tmpSql = `match(${toMatchSqlColumnName(key)}) against( ? in boolean mode)`;
256
- } else if (equalsIgnoreCase(KeysOfConditions.$RANGE, compare)) {
257
- const array = [...value0];
258
- if (isNotEmpty(array) && array.length === 2) {
259
- tmpSql = `(${toSqlColumnName(key)} between ? and ? )`;
260
- tmpArgList.push(...array);
261
- }
262
- }
263
-
264
- tmpSqlList.push(tmpSql);
265
- }
266
- }
267
-
268
- if (isEmpty(tmpArgList) && !hasNoArgSql) {
269
- return null;
270
- }
271
-
272
- const sql = '( ' + tmpSqlList.join(' and ') + ' )';
273
- return new SqlSegArg(sql, tmpArgList);
274
- }
275
-
276
- /**
277
- * 参数校验
278
- * @param key
279
- * @param map
280
- * @private
281
- */
282
- private generateByCompareKeyCheckParam(key: string, map: ICompareCondition) {
283
- if (isEmpty(map)) {
284
- return null;
285
- }
286
-
287
- const compareSet = Object.keys(map);
288
-
289
- const throwCommonException = (name: string, type: string) => {
290
- throw new CommonException(Exceptions.REQUEST_PARAM_ERROR, `${name}参数必须是${type}`);
291
- };
292
-
293
- for (let i = 0; i < compareSet.length; i++) {
294
- const compare = compareSet[i];
295
-
296
- if (hasCompareKey(compare)) {
297
- const value0 = map[compare];
298
-
299
- if (equalsIgnoreCase(KeysOfConditions.$GT, compare)) {
300
- if (!isBasicType(value0)) {
301
- throwCommonException(KeysOfConditions.$GT, '字符串、数字');
302
- }
303
- } else if (equalsIgnoreCase(KeysOfConditions.$GTE, compare)) {
304
- if (!isBasicType(value0)) {
305
- throwCommonException(KeysOfConditions.$GTE, '字符串、数字');
306
- }
307
- } else if (equalsIgnoreCase(KeysOfConditions.$LT, compare)) {
308
- if (!isBasicType(value0)) {
309
- throwCommonException(KeysOfConditions.$LT, '字符串、数字');
310
- }
311
- } else if (equalsIgnoreCase(KeysOfConditions.$LTE, compare)) {
312
- if (!isBasicType(value0)) {
313
- throwCommonException(KeysOfConditions.$LTE, '字符串、数字');
314
- }
315
- } else if (equalsIgnoreCase(KeysOfConditions.$NE, compare)) {
316
- if (!isBasicType(value0)) {
317
- throwCommonException(KeysOfConditions.$NE, '字符串、数字');
318
- }
319
- } else if (equalsIgnoreCase(KeysOfConditions.$IN, compare)) {
320
- valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是基本数据类型(数字、字符串)`);
321
- } else if (equalsIgnoreCase(KeysOfConditions.$NIN, compare)) {
322
- valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是基本数据类型(数字、字符串)`);
323
- } else if (equalsIgnoreCase(KeysOfConditions.$LIKE, compare)) {
324
- if (!isBasicType(value0)) {
325
- throwCommonException(KeysOfConditions.$LIKE, '字符串');
326
- }
327
- } else if (equalsIgnoreCase(KeysOfConditions.$NOT_LIKE, compare)) {
328
- if (!isBasicType(value0)) {
329
- throwCommonException(KeysOfConditions.$NOT_LIKE, '字符串');
330
- }
331
- }
332
-
333
-
334
- else if (equalsIgnoreCase(KeysOfConditions.$LIKE_INCLUDE, compare)) {
335
- if (!isBasicType(value0)) {
336
- throwCommonException(KeysOfConditions.$LIKE_INCLUDE, '字符串');
337
- }
338
- } else if (equalsIgnoreCase(KeysOfConditions.$NOT_LIKE_INCLUDE, compare)) {
339
- if (!isBasicType(value0)) {
340
- throwCommonException(KeysOfConditions.$NOT_LIKE_INCLUDE, '字符串');
341
- }
342
- }
343
-
344
-
345
- else if (equalsIgnoreCase(KeysOfConditions.$MATCH, compare)) {
346
- if (!isBasicType(value0)) {
347
- throwCommonException(KeysOfConditions.$MATCH, '字符串');
348
- }
349
- } else if (equalsIgnoreCase(KeysOfConditions.$MATCH_BOOL, compare)) {
350
- if (!isBasicType(value0)) {
351
- throwCommonException(KeysOfConditions.$MATCH_BOOL, '字符串');
352
- }
353
- } else if (equalsIgnoreCase(KeysOfConditions.$RANGE, compare)) {
354
- valueChecker.checkBasicArrayAndNotEmpty(value0, `操作符${compare}的参数必须是一个非空数组,且元素是两个数字组成的数组`);
355
-
356
- const array = [...value0];
357
- if (isNotEmpty(array) && array.length === 2) {
358
- for (let j = 0; j < array.length; j++) {
359
- const arrayElement = array[j];
360
- if (!isNumber(arrayElement)) {
361
- throwCommonException(KeysOfConditions.$RANGE, '数组(两个数字)');
362
- }
363
- }
364
- } else {
365
- throwCommonException(KeysOfConditions.$RANGE, '数组(两个数字)');
366
- }
367
- }
368
- }
369
- }
370
- }
371
- }
372
-
373
- export { CrudProGenSqlCondition };
@@ -1,202 +0,0 @@
1
- import { CrudProServiceBase } from './CrudProServiceBase';
2
- import { CommonException, Exceptions } from '../exceptions';
3
- import { MixinUtils } from '../utils/MixinUtils';
4
- import {KeysOfSimpleSQL, KeysOfSqlResPicker, SqlDbType} from '../models/keys';
5
- import {RequestCfgModel} from "../models/RequestCfgModel";
6
-
7
- const { equalsIgnoreCase, isEmpty, isNotEmpty } = MixinUtils;
8
-
9
- class CrudProGenSqlService extends CrudProServiceBase {
10
- public async generateSQLList() {
11
- const exeCtx = this.getExecuteContext();
12
- const reqCfg = exeCtx.getCfgModel();
13
- const sqlSimpleName = reqCfg.sqlSimpleName;
14
-
15
- // 简单模式
16
- const isSimpleMode = isNotEmpty(sqlSimpleName) && sqlSimpleName.startsWith('SIMPLE_');
17
-
18
- // 拼接简单模式的SQL
19
- if (isSimpleMode) {
20
- this.generateOriginSql();
21
- }
22
-
23
- await this.generateExecuteSql();
24
- }
25
-
26
- private generateOriginSql() {
27
- const exeCtx = this.getExecuteContext();
28
-
29
- const cfgModel = exeCtx.getCfgModel();
30
- const simpleSqlName = cfgModel.sqlSimpleName;
31
-
32
- // 只有当设置了simpleSqlName时,才启用内置的SQL生成
33
- if (isEmpty(simpleSqlName)) {
34
- return;
35
- }
36
-
37
- cfgModel.sqlCfgList = [];
38
-
39
- let sql1 = null;
40
- let sql2 = null;
41
- let sql3 = null;
42
- if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY, simpleSqlName)) {
43
- sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys @@offsetLimit';
44
- cfgModel.addSqlCfgModel('rows', sql1);
45
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY_ONE, simpleSqlName)) {
46
- sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys limit 1';
47
- cfgModel.addSqlCfgModel('row', sql1, KeysOfSqlResPicker.RESULT_FIRST_ROW);
48
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY_COUNT, simpleSqlName)) {
49
- sql1 = 'select count(0) as total_count from @@table where @@asWhere:condition';
50
-
51
- cfgModel.addSqlCfgModel('total_count', sql1, KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
52
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_QUERY_PAGE, simpleSqlName)) {
53
- sql1 = 'select @@columns from @@table where @@asWhere:condition @@orderBys @@offsetLimit ';
54
- sql2 = 'select count(0) as total_count from @@table where @@asWhere:condition';
55
-
56
- cfgModel.addSqlCfgModel('rows', sql1);
57
- cfgModel.addSqlCfgModel('total_count', sql2, KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
58
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_DELETE, simpleSqlName)) {
59
- sql1 = this.generateOriginSqlForDelete(cfgModel);
60
- cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
61
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_INSERT, simpleSqlName)) {
62
- sql1 = this.generateOriginSqlForInsert(cfgModel);
63
- cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
64
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_UPDATE, simpleSqlName)) {
65
- sql1 = 'update @@table set @@asUpdate:data where @@asWhere:condition ';
66
- cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
67
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_INSERT_ON_DUPLICATE_UPDATE, simpleSqlName)) {
68
- sql1 = this.generateOriginSqlForDuplicateInsert(cfgModel);
69
- cfgModel.addSqlCfgModel('affected', sql1, KeysOfSqlResPicker.UPDATE_RESULT);
70
- } else if (equalsIgnoreCase(KeysOfSimpleSQL.SIMPLE_INSERT_OR_UPDATE, simpleSqlName)) {
71
- sql1 = 'select count(0) as total_count from @@table where @@asWhere:condition ';
72
- sql2 = 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data )';
73
- sql3 = 'update @@table set @@asUpdate:data where @@asWhere:condition ';
74
-
75
- const insertWhen2 = {
76
- functionName: 'eq',
77
- functionParams: [{ contextAsNumber: 'res.total_count' }, { constNumber: 0 }],
78
- };
79
- const updateWhen3 = {
80
- functionName: 'gt',
81
- functionParams: [{ contextAsNumber: 'res.total_count' }, { constNumber: 0 }],
82
- };
83
-
84
- cfgModel.addSqlCfgModel('total_count', sql1, KeysOfSqlResPicker.RESULT_TOTAL_COUNT);
85
- cfgModel.addSqlCfgModel('insert_affected', sql2, KeysOfSqlResPicker.UPDATE_RESULT, insertWhen2);
86
- cfgModel.addSqlCfgModel('update_affected', sql3, KeysOfSqlResPicker.UPDATE_RESULT, updateWhen3);
87
- }
88
-
89
- if (isEmpty(sql1)) {
90
- throw new CommonException(Exceptions.CFG_NOT_SUPPORT_THE_SIMPLE_SQL, simpleSqlName);
91
- }
92
- }
93
-
94
- /**
95
- * 删除语句
96
- * @param cfgModel
97
- * @private
98
- */
99
- private generateOriginSqlForDelete(cfgModel: RequestCfgModel) : string {
100
- if (cfgModel.sqlDdType === SqlDbType.postgres) {
101
- return 'delete from @@table where @@asWhere:condition ';
102
- }
103
- if (cfgModel.sqlDdType === SqlDbType.sqlserver) {
104
- return 'delete from @@table where @@asWhere:condition ';
105
- }
106
- return 'delete from @@table where @@asWhere:condition limit 100 '; // 删除操作,不能一次性删除太多
107
- }
108
-
109
- /**
110
- * 创建插入OR更新语句
111
- * @param cfgModel
112
- * @private
113
- */
114
- private generateOriginSqlForDuplicateInsert(cfgModel: RequestCfgModel) : string {
115
- if (cfgModel.sqlDdType === SqlDbType.postgres) {
116
- const uniqueColumn = cfgModel.uniqueColumn ; // id
117
- if (!Array.isArray(uniqueColumn) || uniqueColumn.length === 0) {
118
- throw new CommonException(Exceptions.CFG_ERROR_POSTGRES_UNIQUE_COLUMNS_NULL)
119
- }
120
- const unique_column = uniqueColumn.map((s)=>{
121
- return `"${s}"`;
122
- }).join(",")
123
- return `insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) ON CONFLICT (${unique_column}) DO UPDATE set @@asUpdate:data `; // 关键字的前后,必须有空格
124
- }
125
-
126
-
127
- if (cfgModel.sqlDdType === SqlDbType.sqlserver) {
128
- const uniqueColumn = cfgModel.uniqueColumn ; // id
129
- if (uniqueColumn.length !== 1) {
130
- throw new CommonException(Exceptions.CFG_UNIQUE_COLUMN_COUNT_MUST_ONE);
131
- }
132
-
133
- const uniqueColumnStr = uniqueColumn[0];
134
- const uniqueColumnVal = "@@data." + uniqueColumnStr;
135
-
136
- const sql = "" +
137
- `IF EXISTS (SELECT 1 FROM @@table WHERE [${uniqueColumnStr}] = ${uniqueColumnVal})` +
138
- "BEGIN\n" +
139
- " UPDATE @@table\n" +
140
- " SET @@asUpdate:data\n" +
141
- ` WHERE [${uniqueColumnStr}] = ${uniqueColumnVal} ;\n` +
142
- "END\n" +
143
- "ELSE\n" +
144
- "BEGIN\n" +
145
- " INSERT INTO @@table ( @@asInsertKeys:data )\n" +
146
- " VALUES ( @@asInsertValues:data );\n" +
147
- "END";
148
-
149
- return sql;
150
- }
151
-
152
-
153
- return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) on duplicate key update @@asUpdate:data '; // 关键字的前后,必须有空格
154
- }
155
-
156
-
157
- /**
158
- * 创建插入语句
159
- * @param cfgModel
160
- * @private
161
- */
162
- private generateOriginSqlForInsert(cfgModel: RequestCfgModel): string {
163
- if (cfgModel.sqlDdType === SqlDbType.postgres) {
164
- return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data ) RETURNING * ';
165
- }
166
- if (cfgModel.sqlDdType === SqlDbType.sqlserver) {
167
- return 'insert into @@table ( @@asInsertKeys:data ) OUTPUT INSERTED.* values( @@asInsertValues:data ) ';
168
- }
169
- return 'insert into @@table ( @@asInsertKeys:data ) values( @@asInsertValues:data )'; // 关键字的前后,必须有空格
170
- }
171
-
172
-
173
-
174
-
175
- private async generateExecuteSql() {
176
- const exeCtx = this.getExecuteContext();
177
-
178
- const reqCfgModel = exeCtx.getCfgModel();
179
- const sqlCfgList = reqCfgModel.sqlCfgList || [];
180
- const { sqlTable, sqlSchema, sqlDatabase, sqlDdType, maxLimit, columns, columnsRelation } = reqCfgModel;
181
-
182
- for (let i = 0; i < sqlCfgList.length; i++) {
183
- const sqlCfgModel = sqlCfgList[i];
184
-
185
- sqlCfgModel.sqlDdType = MixinUtils.selectNotEmpty(sqlCfgModel.sqlDdType, sqlDdType);
186
- sqlCfgModel.sqlDatabase = MixinUtils.selectNotEmpty(sqlCfgModel.sqlDatabase, sqlDatabase);
187
- sqlCfgModel.sqlSchema = MixinUtils.selectNotEmpty(sqlCfgModel.sqlSchema, sqlSchema);
188
- sqlCfgModel.sqlTable = MixinUtils.selectNotEmpty(sqlCfgModel.sqlTable, sqlTable);
189
- sqlCfgModel.maxLimit = MixinUtils.selectNotEmpty(sqlCfgModel.maxLimit, maxLimit);
190
- sqlCfgModel.columns = MixinUtils.selectNotEmpty(sqlCfgModel.columns, columns);
191
- sqlCfgModel.columnsRelation = MixinUtils.selectNotEmpty(sqlCfgModel.columnsRelation, columnsRelation);
192
-
193
- await this.serviceHub.convertOriginToExecuteSql(sqlCfgModel);
194
-
195
- exeCtx.getSqlCfgModels().push(sqlCfgModel);
196
- }
197
- }
198
-
199
-
200
- }
201
-
202
- export { CrudProGenSqlService };