serviceImpl.vm 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. package ${basePackage}.module.${table.moduleName}.service.${table.businessName};
  2. import org.springframework.stereotype.Service;
  3. import javax.annotation.Resource;
  4. import org.springframework.validation.annotation.Validated;
  5. import org.springframework.transaction.annotation.Transactional;
  6. import java.util.*;
  7. import ${basePackage}.module.${table.moduleName}.controller.${sceneEnum.basePackage}.${table.businessName}.vo.*;
  8. import ${basePackage}.module.${table.moduleName}.dal.dataobject.${table.businessName}.${table.className}DO;
  9. ## 特殊:主子表专属逻辑
  10. #foreach ($subTable in $subTables)
  11. import ${basePackage}.module.${subTable.moduleName}.dal.dataobject.${subTable.businessName}.${subTable.className}DO;
  12. #end
  13. import ${PageResultClassName};
  14. import ${basePackage}.module.${table.moduleName}.convert.${table.businessName}.${table.className}Convert;
  15. import ${basePackage}.module.${table.moduleName}.dal.mysql.${table.businessName}.${table.className}Mapper;
  16. ## 特殊:主子表专属逻辑
  17. #foreach ($subTable in $subTables)
  18. #set ($index = $foreach.count - 1)
  19. import ${basePackage}.module.${subTable.moduleName}.dal.mysql.${subTable.businessName}.${subTable.className}Mapper;
  20. #end
  21. import static ${ServiceExceptionUtilClassName}.exception;
  22. import static ${basePackage}.module.${table.moduleName}.enums.ErrorCodeConstants.*;
  23. import cn.hutool.core.collection.CollUtil;
  24. import cn.hutool.core.collection.ListUtil;
  25. /**
  26. * ${table.classComment} Service 实现类
  27. *
  28. * @author ${table.author}
  29. */
  30. @Service
  31. @Validated
  32. public class ${table.className}ServiceImpl implements ${table.className}Service {
  33. @Resource
  34. private ${table.className}Mapper ${classNameVar}Mapper;
  35. ## 特殊:主子表专属逻辑
  36. #foreach ($subTable in $subTables)
  37. #set ($index = $foreach.count - 1)
  38. @Resource
  39. private ${subTable.className}Mapper ${subClassNameVars.get($index)}Mapper;
  40. #end
  41. @Override
  42. ## 特殊:主子表专属逻辑
  43. #if ( $subTables.size() > 0)
  44. @Transactional(rollbackFor = Exception.class)
  45. #end
  46. public ${primaryColumn.javaType} create${simpleClassName}(${sceneEnum.prefixClass}${table.className}CreateReqVO createReqVO) {
  47. // 插入
  48. ${table.className}DO ${classNameVar} = ${table.className}Convert.INSTANCE.convert(createReqVO);
  49. ${classNameVar}Mapper.insert(${classNameVar});
  50. ## 特殊:主子表专属逻辑
  51. #if ( $subTables.size() > 0)
  52. // 插入子表($subTable.classComment)
  53. #foreach ($subTable in $subTables)
  54. #set ($index = $foreach.count - 1)
  55. #set ($subSimpleClassName = $subSimpleClassNames.get($index))
  56. #set ($subJoinColumn = $subJoinColumns.get($index))##当前 join 字段
  57. #set ($SubJoinColumnName = $subJoinColumn.javaField.substring(0,1).toUpperCase() + ${subJoinColumn.javaField.substring(1)})##首字母大写
  58. #if ( $subTable.subJoinMany)
  59. create${subSimpleClassName}List(${classNameVar}.getId(), createReqVO.get${subSimpleClassNames.get($index)}s());
  60. #else
  61. create${subSimpleClassName}(${classNameVar}.getId(), createReqVO.get${subSimpleClassNames.get($index)}());
  62. #end
  63. #end
  64. #end
  65. // 返回
  66. return ${classNameVar}.getId();
  67. }
  68. @Override
  69. ## 特殊:主子表专属逻辑
  70. #if ( $subTables.size() > 0)
  71. @Transactional(rollbackFor = Exception.class)
  72. #end
  73. public void update${simpleClassName}(${sceneEnum.prefixClass}${table.className}UpdateReqVO updateReqVO) {
  74. // 校验存在
  75. validate${simpleClassName}Exists(updateReqVO.getId());
  76. // 更新
  77. ${table.className}DO updateObj = ${table.className}Convert.INSTANCE.convert(updateReqVO);
  78. ${classNameVar}Mapper.updateById(updateObj);
  79. ## 特殊:主子表专属逻辑
  80. #if ( $subTables.size() > 0)
  81. // 更新子表
  82. #foreach ($subTable in $subTables)
  83. #set ($index = $foreach.count - 1)
  84. #set ($subSimpleClassName = $subSimpleClassNames.get($index))
  85. #set ($subJoinColumn = $subJoinColumns.get($index))##当前 join 字段
  86. #set ($SubJoinColumnName = $subJoinColumn.javaField.substring(0,1).toUpperCase() + ${subJoinColumn.javaField.substring(1)})##首字母大写
  87. #if ( $subTable.subJoinMany)
  88. update${subSimpleClassName}List(updateReqVO.getId(), updateReqVO.get${subSimpleClassNames.get($index)}s());
  89. #else
  90. update${subSimpleClassName}(updateReqVO.getId(), updateReqVO.get${subSimpleClassNames.get($index)}());
  91. #end
  92. #end
  93. #end
  94. }
  95. @Override
  96. ## 特殊:主子表专属逻辑
  97. #if ( $subTables.size() > 0)
  98. @Transactional(rollbackFor = Exception.class)
  99. #end
  100. public void delete${simpleClassName}(${primaryColumn.javaType} id) {
  101. // 校验存在
  102. validate${simpleClassName}Exists(id);
  103. // 删除
  104. ${classNameVar}Mapper.deleteById(id);
  105. ## 特殊:主子表专属逻辑
  106. #if ( $subTables.size() > 0)
  107. // 删除子表
  108. #foreach ($subTable in $subTables)
  109. #set ($index = $foreach.count - 1)
  110. #set ($subSimpleClassName = $subSimpleClassNames.get($index))
  111. #set ($subJoinColumn = $subJoinColumns.get($index))##当前 join 字段
  112. #set ($SubJoinColumnName = $subJoinColumn.javaField.substring(0,1).toUpperCase() + ${subJoinColumn.javaField.substring(1)})##首字母大写
  113. delete${subSimpleClassName}By${SubJoinColumnName}(id);
  114. #end
  115. #end
  116. }
  117. private void validate${simpleClassName}Exists(${primaryColumn.javaType} id) {
  118. if (${classNameVar}Mapper.selectById(id) == null) {
  119. throw exception(${simpleClassName_underlineCase.toUpperCase()}_NOT_EXISTS);
  120. }
  121. }
  122. @Override
  123. public ${table.className}DO get${simpleClassName}(${primaryColumn.javaType} id) {
  124. return ${classNameVar}Mapper.selectById(id);
  125. }
  126. @Override
  127. public PageResult<${table.className}DO> get${simpleClassName}Page(${sceneEnum.prefixClass}${table.className}PageReqVO pageReqVO) {
  128. return ${classNameVar}Mapper.selectPage(pageReqVO);
  129. }
  130. @Override
  131. public List<${table.className}DO> get${simpleClassName}List(${sceneEnum.prefixClass}${table.className}ExportReqVO exportReqVO) {
  132. return ${classNameVar}Mapper.selectList(exportReqVO);
  133. }
  134. ## 特殊:主子表专属逻辑
  135. #foreach ($subTable in $subTables)
  136. #set ($index = $foreach.count - 1)
  137. #set ($subSimpleClassName = $subSimpleClassNames.get($index))
  138. #set ($subPrimaryColumn = $subPrimaryColumns.get($index))##当前 primary 字段
  139. #set ($subJoinColumn = $subJoinColumns.get($index))##当前 join 字段
  140. #set ($SubJoinColumnName = $subJoinColumn.javaField.substring(0,1).toUpperCase() + ${subJoinColumn.javaField.substring(1)})##首字母大写
  141. #set ($subClassNameVar = $subClassNameVars.get($index))
  142. // ==================== 子表($subTable.classComment) ====================
  143. ## 情况一:MASTER_ERP 时,需要分查询页子表
  144. #if ( $table.templateType == 11 )
  145. @Override
  146. public PageResult<${subTable.className}DO> get${subSimpleClassName}Page(PageParam pageReqVO, ${subJoinColumn.javaType} ${subJoinColumn.javaField}) {
  147. return ${subClassNameVars.get($index)}Mapper.selectPage(pageReqVO, ${subJoinColumn.javaField});
  148. }
  149. ## 情况二:非 MASTER_ERP 时,需要列表查询子表
  150. #else
  151. #if ( $subTable.subJoinMany )
  152. @Override
  153. public List<${subTable.className}DO> get${subSimpleClassName}ListBy${SubJoinColumnName}(${subJoinColumn.javaType} ${subJoinColumn.javaField}) {
  154. return ${subClassNameVars.get($index)}Mapper.selectListBy${SubJoinColumnName}(${subJoinColumn.javaField});
  155. }
  156. #else
  157. @Override
  158. public ${subTable.className}DO get${subSimpleClassName}By${SubJoinColumnName}(${subJoinColumn.javaType} ${subJoinColumn.javaField}) {
  159. return ${subClassNameVars.get($index)}Mapper.selectBy${SubJoinColumnName}(${subJoinColumn.javaField});
  160. }
  161. #end
  162. #end
  163. ## 情况一:MASTER_ERP 时,支持单个的新增、修改、删除操作
  164. #if ( $table.templateType == 11 )
  165. @Override
  166. public ${subPrimaryColumn.javaType} create${subSimpleClassName}(@Valid ${subTable.className}DO ${subClassNameVar}) {
  167. ${subClassNameVars.get($index)}Mapper.insert(${subClassNameVar});
  168. return ${subClassNameVar}.getId();
  169. }
  170. @Override
  171. public void update${subSimpleClassName}(@Valid ${subTable.className}DO ${subClassNameVar}) {
  172. ${subClassNameVars.get($index)}Mapper.updateById(${subClassNameVar});
  173. }
  174. @Override
  175. public void delete${subSimpleClassName}(${subPrimaryColumn.javaType} id) {
  176. ${subClassNameVars.get($index)}Mapper.deleteById(id);
  177. }
  178. ## 情况二:非 MASTER_ERP 时,支持批量的新增、修改操作
  179. #else
  180. #if ( $subTable.subJoinMany)
  181. private void create${subSimpleClassName}List(${primaryColumn.javaType} ${subJoinColumn.javaField}, List<${subTable.className}DO> list) {
  182. list.forEach(o -> o.set$SubJoinColumnName(${subJoinColumn.javaField}));
  183. ${subClassNameVars.get($index)}Mapper.insertBatch(list);
  184. }
  185. private void update${subSimpleClassName}List(${primaryColumn.javaType} ${subJoinColumn.javaField}, List<${subTable.className}DO> list) {
  186. delete${subSimpleClassName}By${SubJoinColumnName}(${subJoinColumn.javaField});
  187. create${subSimpleClassName}List(${subJoinColumn.javaField}, list);
  188. }
  189. #else
  190. private void create${subSimpleClassName}(${primaryColumn.javaType} ${subJoinColumn.javaField}, ${subTable.className}DO ${subClassNameVar}) {
  191. ${subClassNameVar}.set$SubJoinColumnName(${subJoinColumn.javaField});
  192. ${subClassNameVars.get($index)}Mapper.insert(${subClassNameVar});
  193. }
  194. private void update${subSimpleClassName}(${primaryColumn.javaType} ${subJoinColumn.javaField}, ${subTable.className}DO ${subClassNameVar}) {
  195. ${subClassNameVar}.set$SubJoinColumnName(${subJoinColumn.javaField});
  196. ${subClassNameVars.get($index)}Mapper.updateById(${subClassNameVar});
  197. }
  198. #end
  199. private void delete${subSimpleClassName}By${SubJoinColumnName}(${primaryColumn.javaType} ${subJoinColumn.javaField}) {
  200. ${subClassNameVars.get($index)}Mapper.deleteBy${SubJoinColumnName}(${subJoinColumn.javaField});
  201. }
  202. #end
  203. #end
  204. }