From 6dc11a081203cad18b2fc7835d7532e08801c707 Mon Sep 17 00:00:00 2001 From: eight <641137800@qq.com> Date: 星期四, 24 十月 2024 11:31:06 +0800 Subject: [PATCH] Fix 事务Bug @DevRentService --- jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java | 85 +++++----------------------- jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/devrent/DevRentServiceImpl.java | 41 ++++++------- 2 files changed, 35 insertions(+), 91 deletions(-) diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java index 54cb342..05e731b 100644 --- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java +++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devrent/DevRentController.java @@ -34,7 +34,7 @@ import javax.servlet.http.HttpServletResponse; import javax.validation.Valid; -@Tag(name = "绠$悊鍚庡彴 - 瑁呮満鎷嗘満") +@Tag(name = "瑁呮満鎷嗘満") @RestController @RequestMapping("/ecg/dev-rent") @Validated @@ -55,122 +55,67 @@ @Operation(summary = "") @PreAuthorize("@ss.hasPermission('ecg:doctor:task')") public CommonResult<Long> routineFinish(@Valid @RequestBody RoutineFinishReqVO routineFinishReqVO) { - try { - CommonResult<Long> result = devRentService.routineFinishOperation(routineFinishReqVO); - return result; - } catch ( RuntimeException runtimeException ) { - String err = ExceptionUtils.formatException( runtimeException ); - log.error("routineFinish: " + err); - return CommonResult.error(DEV_INSTALL_EXCEPTION); - } + CommonResult<Long> result = devRentService.routineFinishOperation(routineFinishReqVO); + return result; } @PostMapping("/dev-ready") @Operation(summary = "璁惧棰嗙敤") @PreAuthorize("@ss.hasPermission('ecg:doctor:task')") public CommonResult<Long> devReady(@Valid @RequestBody DevRentSaveReqVO createReqVO) { - try { - CommonResult<Long> result = devRentService.readyOperation(createReqVO); - return result; - } catch ( RuntimeException runtimeException ) { - String err = ExceptionUtils.formatException( runtimeException ); - log.error("devReady: " + err); - return CommonResult.error(DEV_INSTALL_EXCEPTION); - } + CommonResult<Long> result = devRentService.readyOperation(createReqVO); + return result; } @PostMapping("/dev-install") @Operation(summary = "瑁呮満") @PreAuthorize("@ss.hasPermission('ecg:doctor:task')") public CommonResult<Long> devInstall(@Valid @RequestBody DevRentSaveReqVO createReqVO) { - try { - return devRentService.installOperation(createReqVO); - } catch ( RuntimeException runtimeException ) { - String err = ExceptionUtils.formatException( runtimeException ); - log.error("devInstall: " + err); - return CommonResult.error(DEV_INSTALL_EXCEPTION); - } + return devRentService.installOperation(createReqVO); } @PostMapping("/dev-dismantle") @Operation(summary = "鎷嗘満") @PreAuthorize("@ss.hasPermission('ecg:doctor:task')") public CommonResult<Long> devDismantle(@Valid @RequestBody DevRentSaveReqVO createReqVO) { - try { - devRentService.dismantleOperation(createReqVO); - return CommonResult.success(0L); - } catch ( RuntimeException runtimeException ) { - String err = ExceptionUtils.formatException( runtimeException ); - log.error("devDismantle: " + err); - return CommonResult.error(DEV_DISMANTLE_EXCEPTION); - } + devRentService.dismantleOperation(createReqVO); + return CommonResult.success(0L); } @PostMapping("/dev-data-entry") @Operation(summary = "鏁版嵁褰曞叆") @PreAuthorize("@ss.hasPermission('ecg:doctor:task')") public CommonResult<Long> devDataEntry(@Valid @RequestBody DevRentSaveReqVO createReqVO) { - try { - devRentService.dataEntryOperation(createReqVO); - return CommonResult.success(0L); - } catch ( RuntimeException runtimeException ) { - String err = ExceptionUtils.formatException( runtimeException ); - log.error("devDismantle: " + err); - return CommonResult.error(DEV_DISMANTLE_EXCEPTION); - } + devRentService.dataEntryOperation(createReqVO); + return CommonResult.success(0L); } - @PostMapping("/routine-check-cancel") @Operation(summary = "鍙栨秷甯歌妫�鏌�") @PreAuthorize("@ss.hasPermission('ecg:doctor:task')") public CommonResult<Long> routineCheckCancel(@Valid @RequestBody DevCancelReqVO cancelReqVO) { - try { - return devRentService.cancelRoutineOperation(cancelReqVO); - } catch ( RuntimeException runtimeException ) { - String err = ExceptionUtils.formatException( runtimeException ); - log.error("routineCheckCancel: " + err); - return CommonResult.error(ROUTINE_CANCEL_EXCEPTION); - } + return devRentService.cancelRoutineOperation(cancelReqVO); } @PostMapping("/dev-ready-cancel") @Operation(summary = "鍙栨秷棰嗙敤") @PreAuthorize("@ss.hasPermission('ecg:doctor:task')") public CommonResult<Long> devReadyCancel(@Valid @RequestBody DevCancelReqVO cancelReqVO) { - try { - return devRentService.cancelReadyOperation(cancelReqVO); - } catch ( RuntimeException runtimeException ) { - String err = ExceptionUtils.formatException( runtimeException ); - log.error("devReadyCancel: " + err); - return CommonResult.error(DEV_RECEIVE_CANCEL_EXCEPTION); - } + return devRentService.cancelReadyOperation(cancelReqVO); } @PostMapping("/dev-install-cancel") @Operation(summary = "鍙栨秷瑁呮満") @PreAuthorize("@ss.hasPermission('ecg:doctor:task')") public CommonResult<Long> devInstallCancel(@Valid @RequestBody DevCancelReqVO cancelReqVO) { - try { - return devRentService.cancelInstallOperation(cancelReqVO); - } catch ( RuntimeException runtimeException ) { - String err = ExceptionUtils.formatException( runtimeException ); - log.error("devInstallCancel: " + err); - return CommonResult.error(DEV_INSTALL_CANCEL_EXCEPTION); - } + return devRentService.cancelInstallOperation(cancelReqVO); } @PostMapping("/dev-lose") @Operation(summary = "閬楀け") @PreAuthorize("@ss.hasPermission('ecg:doctor:task')") public CommonResult<Long> devLose(@Valid @RequestBody DevRentSaveReqVO loseReqVO) { - try { - return devRentService.loseOperation(loseReqVO); - } catch ( RuntimeException runtimeException ) { - String err = ExceptionUtils.formatException( runtimeException ); - log.error("devLose: " + err); - return CommonResult.error(DEV_LOSE_EXCEPTION); - } + return devRentService.loseOperation(loseReqVO); } @PostMapping("/create") @@ -237,7 +182,7 @@ } @GetMapping("/get-free-rent") - @Operation(summary = "鑾峰彇宸查鍙栫璧佹儏鍐�") + @Operation(summary = "鏍规嵁鎮h�呮垨璁惧, 鑾峰彇宸查鍙栫璧佹儏鍐�") @PreAuthorize("@ss.hasPermission('ecg:doctor:task')") public CommonResult<DevRentRespVO> getFreeRent( @Valid DevRentSearchReqVO searchReqVO ) { diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/devrent/DevRentServiceImpl.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/devrent/DevRentServiceImpl.java index 63bfaf8..d29ea73 100644 --- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/devrent/DevRentServiceImpl.java +++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/devrent/DevRentServiceImpl.java @@ -60,6 +60,7 @@ } @Override + @Transactional(rollbackFor = Exception.class) public CommonResult<Long> routineFinishOperation(RoutineFinishReqVO routineFinishReqVO) { DevRentSaveReqVO createReqVO = BeanUtils.toBean(routineFinishReqVO, DevRentSaveReqVO.class); @@ -71,9 +72,9 @@ if (null == rent_id) { List<DevRentDO> devRentDOList = devRentMapper.selectByPatIdAndState(createReqVO.getPatId(), DevRentStateEnum.FREE.getState()); if (devRentDOList.size() == 0) - return CommonResult.error(DEV_INSTALL_NOT_APPOINTMENT); + throw exception(DEV_INSTALL_NOT_APPOINTMENT); else if (devRentDOList.size() != 1) { - return CommonResult.error(DEV_INSTALL_EXCEPTION); + throw exception(DEV_INSTALL_EXCEPTION); } rent_id = devRentDOList.getFirst().getId(); @@ -124,7 +125,7 @@ } @Override - @Transactional + @Transactional(rollbackFor = Exception.class) public CommonResult<Long> readyOperation(DevRentSaveReqVO createReqVO) { Long userId = SecurityFrameworkUtils.getLoginUserId(); String userNickname = SecurityFrameworkUtils.getLoginUserNickname(); @@ -132,16 +133,16 @@ // 鏍囨敞璁惧 宸查鍙� Integer ret = markDevRecieved(createReqVO.getDevId()); if (null == ret || 0 == ret) { - return CommonResult.error(DEVICE_NOT_FREE); + throw exception(DEVICE_NOT_FREE); } Long rent_id = createReqVO.getId(); if (null == rent_id) { List<DevRentDO> devRentDOList = devRentMapper.selectByPatIdAndState(createReqVO.getPatId(), DevRentStateEnum.FREE.getState()); if (devRentDOList.size() == 0) - return CommonResult.error(DEV_INSTALL_NOT_APPOINTMENT); + throw exception(DEV_INSTALL_NOT_APPOINTMENT); else if (devRentDOList.size() != 1) { - return CommonResult.error(DEV_INSTALL_EXCEPTION); + throw exception(DEV_INSTALL_EXCEPTION); } rent_id = devRentDOList.getFirst().getId(); @@ -192,7 +193,7 @@ } @Override - @Transactional + @Transactional(rollbackFor = Exception.class) public CommonResult<Long> installOperation(DevRentSaveReqVO createReqVO) { Long userId = SecurityFrameworkUtils.getLoginUserId(); String userNickname = SecurityFrameworkUtils.getLoginUserNickname(); @@ -200,7 +201,7 @@ // 璁剧疆璁惧 浣跨敤涓� Integer ret = markDevInUse(createReqVO.getDevId()); if (null == ret || 0 == ret) { - return CommonResult.error(DEVICE_NOT_RECEIVED); + throw exception(DEVICE_NOT_RECEIVED); } Long rent_id = createReqVO.getId(); @@ -215,9 +216,9 @@ if (null == jobRecordDO) { List<DevRentDO> devRentDOList = devRentMapper.selectByPatIdAndState(createReqVO.getPatId(), DevRentStateEnum.READY.getState()); if (devRentDOList.size() == 0) - return CommonResult.error(DEV_INSTALL_NOT_RECEIVED); + throw exception(DEV_INSTALL_NOT_RECEIVED); else if (devRentDOList.size() != 1) { - return CommonResult.error(DEV_INSTALL_EXCEPTION); + throw exception(DEV_INSTALL_EXCEPTION); } rent_id = devRentDOList.getFirst().getId(); @@ -261,7 +262,7 @@ } @Override - @Transactional + @Transactional(rollbackFor = Exception.class) public Long dismantleOperation(DevRentSaveReqVO updateReqVO) { updateReqVO.setState( DevRentStateEnum.DISMANTLED.getState() ); updateDevRent( updateReqVO ); @@ -302,7 +303,7 @@ } @Override - @Transactional + @Transactional(rollbackFor = Exception.class) public Long dataEntryOperation(DevRentSaveReqVO updateReqVO) { updateReqVO.setState( DevRentStateEnum.DATAENTERED.getState() ); updateDevRent( updateReqVO ); @@ -340,7 +341,7 @@ // 甯歌妫�鏌� 鍙栨秷 @Override - @Transactional + @Transactional(rollbackFor = Exception.class) public CommonResult<Long> cancelRoutineOperation(DevCancelReqVO cancelReqVO) { Long userId = SecurityFrameworkUtils.getLoginUserId(); String userNickname = SecurityFrameworkUtils.getLoginUserNickname(); @@ -353,7 +354,7 @@ if (null == rent_id) { List<DevRentDO> devRentDOList = devRentMapper.selectByPatIdAndState(createReqVO.getPatId(), DevRentStateEnum.FREE.getState()); if (devRentDOList.size() != 1) - return CommonResult.error(ROUTINE_CHECK_EXIST); + throw exception(ROUTINE_CHECK_EXIST); rent_id = devRentDOList.getFirst().getId(); createReqVO.setId( rent_id ); @@ -395,7 +396,7 @@ } @Override - @Transactional + @Transactional(rollbackFor = Exception.class) public CommonResult<Long> cancelReadyOperation(DevCancelReqVO cancelReqVO) { Long userId = SecurityFrameworkUtils.getLoginUserId(); String userNickname = SecurityFrameworkUtils.getLoginUserNickname(); @@ -413,7 +414,7 @@ if (null == rent_id) { List<DevRentDO> devRentDOList = devRentMapper.selectByPatIdAndState(createReqVO.getPatId(), DevRentStateEnum.FREE.getState()); if (devRentDOList.size() != 1) - return CommonResult.error(DEV_INSTALL_EXIST); + throw exception(DEV_INSTALL_EXIST); rent_id = devRentDOList.getFirst().getId(); createReqVO.setId( rent_id ); @@ -455,7 +456,7 @@ } @Override - @Transactional + @Transactional(rollbackFor = Exception.class) public CommonResult<Long> cancelInstallOperation(DevCancelReqVO cancelReqVO) { Long userId = SecurityFrameworkUtils.getLoginUserId(); String userNickname = SecurityFrameworkUtils.getLoginUserNickname(); @@ -478,7 +479,7 @@ if (null == jobRecordDO) { List<DevRentDO> devRentDOList = devRentMapper.selectByPatIdAndState(createReqVO.getPatId(), DevRentStateEnum.READY.getState()); if (devRentDOList.size() != 1) - return CommonResult.error(DEV_INSTALL_EXIST); + throw exception(DEV_INSTALL_EXIST); rent_id = devRentDOList.getFirst().getId(); createReqVO.setId( rent_id ); @@ -514,7 +515,7 @@ } @Override - @Transactional + @Transactional(rollbackFor = Exception.class) public CommonResult<Long> loseOperation(DevRentSaveReqVO updateReqVO) { // 璁惧閬楀け鏃�, 鏍囨敞閬楀け markDevLost( updateReqVO.getDevId(), updateReqVO.getReturnTime().toLocalDate() ); @@ -557,8 +558,6 @@ @Override public Long createDevRent(DevRentSaveReqVO createReqVO) { - // - // 鎻掑叆 DevRentDO devRent = BeanUtils.toBean(createReqVO, DevRentDO.class); devRentMapper.insert(devRent); -- Gitblit v1.9.3