From 73eb39be6f9b06b84c7c7f0316ce9d41eafa22eb Mon Sep 17 00:00:00 2001 From: Flow <958079825@qq.com> Date: Fri, 5 Sep 2025 11:14:34 +0800 Subject: [PATCH] =?UTF-8?q?=E8=AE=BE=E5=A4=87=E7=A7=9F=E7=94=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../EquipmentrentController.java | 96 ++++++++++++++++++ .../vo/EquipmentrentPageReqVO.java | 60 ++++++++++++ .../equipmentrent/vo/EquipmentrentRespVO.java | 71 ++++++++++++++ .../vo/EquipmentrentSaveReqVO.java | 66 +++++++++++++ .../equipmentrent/EquipmentrentDO.java | 98 +++++++++++++++++++ .../equipmentrent/EquipmentrentMapper.java | 38 +++++++ .../equipmentrent/EquipmentrentService.java | 62 ++++++++++++ .../EquipmentrentServiceImpl.java | 90 +++++++++++++++++ .../equipmentrent/EquipmentrentMapper.xml | 12 +++ .../src/main/resources/application.yaml | 1 + 10 files changed, 594 insertions(+) create mode 100644 yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/EquipmentrentController.java create mode 100644 yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentPageReqVO.java create mode 100644 yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentRespVO.java create mode 100644 yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentSaveReqVO.java create mode 100644 yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/dal/dataobject/equipmentrent/EquipmentrentDO.java create mode 100644 yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/dal/mysql/equipmentrent/EquipmentrentMapper.java create mode 100644 yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/service/equipmentrent/EquipmentrentService.java create mode 100644 yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/service/equipmentrent/EquipmentrentServiceImpl.java create mode 100644 yudao-module-system/src/main/resources/mapper/equipmentrent/EquipmentrentMapper.xml diff --git a/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/EquipmentrentController.java b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/EquipmentrentController.java new file mode 100644 index 0000000..aea452a --- /dev/null +++ b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/EquipmentrentController.java @@ -0,0 +1,96 @@ +package cn.iocoder.yudao.module.system.controller.admin.equipmentrent; + +import org.springframework.web.bind.annotation.*; +import javax.annotation.Resource; +import org.springframework.validation.annotation.Validated; +import org.springframework.security.access.prepost.PreAuthorize; +import io.swagger.v3.oas.annotations.tags.Tag; +import io.swagger.v3.oas.annotations.Parameter; +import io.swagger.v3.oas.annotations.Operation; + +import javax.validation.constraints.*; +import javax.validation.*; +import javax.servlet.http.*; +import java.util.*; +import java.io.IOException; + +import cn.iocoder.yudao.framework.common.pojo.PageParam; +import cn.iocoder.yudao.framework.common.pojo.PageResult; +import cn.iocoder.yudao.framework.common.pojo.CommonResult; +import cn.iocoder.yudao.framework.common.util.object.BeanUtils; +import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; + +import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; + +import cn.iocoder.yudao.framework.apilog.core.annotation.ApiAccessLog; +import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.*; + +import cn.iocoder.yudao.module.system.controller.admin.equipmentrent.vo.*; +import cn.iocoder.yudao.module.system.dal.dataobject.equipmentrent.EquipmentrentDO; +import cn.iocoder.yudao.module.system.service.equipmentrent.EquipmentrentService; + +@Tag(name = "管理后台 - 设备租用") +@RestController +@RequestMapping("/system/equipmentrent") +@Validated +public class EquipmentrentController { + + @Resource + private EquipmentrentService equipmentrentService; + + @PostMapping("/create") + @Operation(summary = "创建设备租用") + public CommonResult createEquipmentrent(@Valid @RequestBody EquipmentrentSaveReqVO createReqVO) { + return success(equipmentrentService.createEquipmentrent(createReqVO)); + } + + @PutMapping("/update") + @Operation(summary = "更新设备租用") + public CommonResult updateEquipmentrent(@Valid @RequestBody EquipmentrentSaveReqVO updateReqVO) { + equipmentrentService.updateEquipmentrent(updateReqVO); + return success(true); + } + + @DeleteMapping("/delete") + @Operation(summary = "删除设备租用") + @Parameter(name = "id", description = "编号", required = true) + public CommonResult deleteEquipmentrent(@RequestParam("id") Long id) { + equipmentrentService.deleteEquipmentrent(id); + return success(true); + } + + @DeleteMapping("/delete-list") + @Parameter(name = "ids", description = "编号", required = true) + public CommonResult deleteEquipmentrentList(@RequestParam("ids") List ids) { + equipmentrentService.deleteEquipmentrentListByIds(ids); + return success(true); + } + + @GetMapping("/get") + @Operation(summary = "获得设备租用") + @Parameter(name = "id", description = "编号", required = true, example = "1024") + public CommonResult getEquipmentrent(@RequestParam("id") Long id) { + EquipmentrentDO equipmentrent = equipmentrentService.getEquipmentrent(id); + return success(BeanUtils.toBean(equipmentrent, EquipmentrentRespVO.class)); + } + + @GetMapping("/page") + @Operation(summary = "获得设备租用分页") + public CommonResult> getEquipmentrentPage(@Valid EquipmentrentPageReqVO pageReqVO) { + PageResult pageResult = equipmentrentService.getEquipmentrentPage(pageReqVO); + return success(BeanUtils.toBean(pageResult, EquipmentrentRespVO.class)); + } + + @GetMapping("/export-excel") + @Operation(summary = "导出设备租用 Excel") + @ApiAccessLog(operateType = EXPORT) + public void exportEquipmentrentExcel(@Valid EquipmentrentPageReqVO pageReqVO, + HttpServletResponse response) throws IOException { + pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE); + List list = equipmentrentService.getEquipmentrentPage(pageReqVO).getList(); + // 导出 Excel + ExcelUtils.write(response, "设备租用.xls", "数据", EquipmentrentRespVO.class, + BeanUtils.toBean(list, EquipmentrentRespVO.class)); + } + +} \ No newline at end of file diff --git a/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentPageReqVO.java b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentPageReqVO.java new file mode 100644 index 0000000..5f2cc28 --- /dev/null +++ b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentPageReqVO.java @@ -0,0 +1,60 @@ +package cn.iocoder.yudao.module.system.controller.admin.equipmentrent.vo; + +import lombok.*; +import java.util.*; +import io.swagger.v3.oas.annotations.media.Schema; +import cn.iocoder.yudao.framework.common.pojo.PageParam; +import org.springframework.format.annotation.DateTimeFormat; +import java.time.LocalDateTime; + +import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND; + +@Schema(description = "管理后台 - 设备租用分页 Request VO") +@Data +public class EquipmentrentPageReqVO extends PageParam { + + @Schema(description = "租用机构ID", example = "31837") + private Long lesseeorgid; + + @Schema(description = "租用机构名称", example = "张三") + private String lesseeorgname; + + @Schema(description = "设备ID", example = "22844") + private Long equipmentid; + + @Schema(description = "设备名称", example = "张三") + private String equipmentname; + + @Schema(description = "设备类型", example = "2") + private String equipmenttype; + + @Schema(description = "租用开始时间") + @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) + private LocalDateTime[] rentstarttime; + + @Schema(description = "租用结束时间") + @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) + private LocalDateTime[] rentendtime; + + @Schema(description = "实际归还时间") + @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) + private LocalDateTime[] actualreturntime; + + @Schema(description = "租用状态(1租用中 2已归还 3超期未还)", example = "1") + private Integer rentstatus; + + @Schema(description = "联系人") + private String contactperson; + + @Schema(description = "联系电话") + private String contactphone; + + @Schema(description = "创建时间") + @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) + private LocalDateTime[] createdtime; + + @Schema(description = "更新时间") + @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) + private LocalDateTime[] updatedtime; + +} \ No newline at end of file diff --git a/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentRespVO.java b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentRespVO.java new file mode 100644 index 0000000..b5590de --- /dev/null +++ b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentRespVO.java @@ -0,0 +1,71 @@ +package cn.iocoder.yudao.module.system.controller.admin.equipmentrent.vo; + +import io.swagger.v3.oas.annotations.media.Schema; +import lombok.*; +import java.util.*; +import org.springframework.format.annotation.DateTimeFormat; +import java.time.LocalDateTime; +import com.alibaba.excel.annotation.*; + +@Schema(description = "管理后台 - 设备租用 Response VO") +@Data +@ExcelIgnoreUnannotated +public class EquipmentrentRespVO { + + @Schema(description = "主键ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "32388") + @ExcelProperty("主键ID") + private Long id; + + @Schema(description = "租用机构ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "31837") + @ExcelProperty("租用机构ID") + private Long lesseeorgid; + + @Schema(description = "租用机构名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "张三") + @ExcelProperty("租用机构名称") + private String lesseeorgname; + + @Schema(description = "设备ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "22844") + @ExcelProperty("设备ID") + private Long equipmentid; + + @Schema(description = "设备名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "张三") + @ExcelProperty("设备名称") + private String equipmentname; + + @Schema(description = "设备类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "2") + @ExcelProperty("设备类型") + private String equipmenttype; + + @Schema(description = "租用开始时间", requiredMode = Schema.RequiredMode.REQUIRED) + @ExcelProperty("租用开始时间") + private LocalDateTime rentstarttime; + + @Schema(description = "租用结束时间", requiredMode = Schema.RequiredMode.REQUIRED) + @ExcelProperty("租用结束时间") + private LocalDateTime rentendtime; + + @Schema(description = "实际归还时间") + @ExcelProperty("实际归还时间") + private LocalDateTime actualreturntime; + + @Schema(description = "租用状态(1租用中 2已归还 3超期未还)", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") + @ExcelProperty("租用状态(1租用中 2已归还 3超期未还)") + private Integer rentstatus; + + @Schema(description = "联系人", requiredMode = Schema.RequiredMode.REQUIRED) + @ExcelProperty("联系人") + private String contactperson; + + @Schema(description = "联系电话", requiredMode = Schema.RequiredMode.REQUIRED) + @ExcelProperty("联系电话") + private String contactphone; + + @Schema(description = "创建时间") + @ExcelProperty("创建时间") + private LocalDateTime createdtime; + + @Schema(description = "更新时间") + @ExcelProperty("更新时间") + private LocalDateTime updatedtime; + +} \ No newline at end of file diff --git a/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentSaveReqVO.java b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentSaveReqVO.java new file mode 100644 index 0000000..415de53 --- /dev/null +++ b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/controller/admin/equipmentrent/vo/EquipmentrentSaveReqVO.java @@ -0,0 +1,66 @@ +package cn.iocoder.yudao.module.system.controller.admin.equipmentrent.vo; + +import io.swagger.v3.oas.annotations.media.Schema; +import lombok.*; +import java.util.*; +import javax.validation.constraints.*; +import org.springframework.format.annotation.DateTimeFormat; +import java.time.LocalDateTime; + +@Schema(description = "管理后台 - 设备租用新增/修改 Request VO") +@Data +public class EquipmentrentSaveReqVO { + + @Schema(description = "主键ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "32388") + private Long id; + + @Schema(description = "租用机构ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "31837") + @NotNull(message = "租用机构ID不能为空") + private Long lesseeorgid; + + @Schema(description = "租用机构名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "张三") + @NotEmpty(message = "租用机构名称不能为空") + private String lesseeorgname; + + @Schema(description = "设备ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "22844") + @NotNull(message = "设备ID不能为空") + private Long equipmentid; + + @Schema(description = "设备名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "张三") + @NotEmpty(message = "设备名称不能为空") + private String equipmentname; + + @Schema(description = "设备类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "2") + @NotEmpty(message = "设备类型不能为空") + private String equipmenttype; + + @Schema(description = "租用开始时间", requiredMode = Schema.RequiredMode.REQUIRED) + @NotNull(message = "租用开始时间不能为空") + private LocalDateTime rentstarttime; + + @Schema(description = "租用结束时间", requiredMode = Schema.RequiredMode.REQUIRED) + @NotNull(message = "租用结束时间不能为空") + private LocalDateTime rentendtime; + + @Schema(description = "实际归还时间") + private LocalDateTime actualreturntime; + + @Schema(description = "租用状态(1租用中 2已归还 3超期未还)", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") + @NotNull(message = "租用状态(1租用中 2已归还 3超期未还)不能为空") + private Integer rentstatus; + + @Schema(description = "联系人", requiredMode = Schema.RequiredMode.REQUIRED) + @NotEmpty(message = "联系人不能为空") + private String contactperson; + + @Schema(description = "联系电话", requiredMode = Schema.RequiredMode.REQUIRED) + @NotEmpty(message = "联系电话不能为空") + private String contactphone; + + @Schema(description = "创建时间") + private LocalDateTime createdtime; + + @Schema(description = "更新时间") + private LocalDateTime updatedtime; + +} \ No newline at end of file diff --git a/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/dal/dataobject/equipmentrent/EquipmentrentDO.java b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/dal/dataobject/equipmentrent/EquipmentrentDO.java new file mode 100644 index 0000000..6e18682 --- /dev/null +++ b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/dal/dataobject/equipmentrent/EquipmentrentDO.java @@ -0,0 +1,98 @@ +package cn.iocoder.yudao.module.system.dal.dataobject.equipmentrent; + +import lombok.*; +import java.util.*; +import java.time.LocalDateTime; +import java.time.LocalDateTime; +import java.time.LocalDateTime; +import java.time.LocalDateTime; +import java.time.LocalDateTime; +import com.baomidou.mybatisplus.annotation.*; +import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO; + +/** + * 设备租用 DO + * + * @author 艾康菲 + */ +@TableName("tb_equipmentrent") +@KeySequence("tb_equipmentrent_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。 +@Data +@ToString(callSuper = true) +@Builder +@NoArgsConstructor +@AllArgsConstructor +public class EquipmentrentDO { + + /** + * 主键ID + */ + @TableId + private Long id; + /** + * 租用机构ID + */ + @TableField("lesseeorgid") + private Long lesseeorgid; + /** + * 租用机构名称 + */ + @TableField("lesseeorgname") + private String lesseeorgname; + /** + * 设备ID + */ + @TableField("equipmentid") + private Long equipmentid; + /** + * 设备名称 + */ + @TableField("equipmentname") + private String equipmentname; + /** + * 设备类型 + */ + @TableField("equipmenttype") + private String equipmenttype; + /** + * 租用开始时间 + */ + @TableField("rentstarttime") + private LocalDateTime rentstarttime; + /** + * 租用结束时间 + */ + @TableField("rentendtime") + private LocalDateTime rentendtime; + /** + * 实际归还时间 + */ + @TableField("actualreturntime") + private LocalDateTime actualreturntime; + /** + * 租用状态(1租用中 2已归还 3超期未还) + */ + @TableField("rentstatus") + private Integer rentstatus; + /** + * 联系人 + */ + @TableField("contactperson") + private String contactperson; + /** + * 联系电话 + */ + private String contactphone; + /** + * 创建时间 + */ + @TableField("createdtime") + private LocalDateTime createdtime; + /** + * 更新时间 + */ + @TableField("updatedtime") + private LocalDateTime updatedtime; + + +} \ No newline at end of file diff --git a/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/dal/mysql/equipmentrent/EquipmentrentMapper.java b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/dal/mysql/equipmentrent/EquipmentrentMapper.java new file mode 100644 index 0000000..d825c2f --- /dev/null +++ b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/dal/mysql/equipmentrent/EquipmentrentMapper.java @@ -0,0 +1,38 @@ +package cn.iocoder.yudao.module.system.dal.mysql.equipmentrent; + +import java.util.*; + +import cn.iocoder.yudao.framework.common.pojo.PageResult; +import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX; +import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX; +import cn.iocoder.yudao.module.system.dal.dataobject.equipmentrent.EquipmentrentDO; +import org.apache.ibatis.annotations.Mapper; +import cn.iocoder.yudao.module.system.controller.admin.equipmentrent.vo.*; + +/** + * 设备租用 Mapper + * + * @author 艾康菲 + */ +@Mapper +public interface EquipmentrentMapper extends BaseMapperX { + + default PageResult selectPage(EquipmentrentPageReqVO reqVO) { + return selectPage(reqVO, new LambdaQueryWrapperX() + .eqIfPresent(EquipmentrentDO::getLesseeorgid, reqVO.getLesseeorgid()) + .likeIfPresent(EquipmentrentDO::getLesseeorgname, reqVO.getLesseeorgname()) + .eqIfPresent(EquipmentrentDO::getEquipmentid, reqVO.getEquipmentid()) + .likeIfPresent(EquipmentrentDO::getEquipmentname, reqVO.getEquipmentname()) + .eqIfPresent(EquipmentrentDO::getEquipmenttype, reqVO.getEquipmenttype()) + .betweenIfPresent(EquipmentrentDO::getRentstarttime, reqVO.getRentstarttime()) + .betweenIfPresent(EquipmentrentDO::getRentendtime, reqVO.getRentendtime()) + .betweenIfPresent(EquipmentrentDO::getActualreturntime, reqVO.getActualreturntime()) + .eqIfPresent(EquipmentrentDO::getRentstatus, reqVO.getRentstatus()) + .eqIfPresent(EquipmentrentDO::getContactperson, reqVO.getContactperson()) + .eqIfPresent(EquipmentrentDO::getContactphone, reqVO.getContactphone()) + .betweenIfPresent(EquipmentrentDO::getCreatedtime, reqVO.getCreatedtime()) + .betweenIfPresent(EquipmentrentDO::getUpdatedtime, reqVO.getUpdatedtime()) + .orderByDesc(EquipmentrentDO::getId)); + } + +} \ No newline at end of file diff --git a/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/service/equipmentrent/EquipmentrentService.java b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/service/equipmentrent/EquipmentrentService.java new file mode 100644 index 0000000..f6b97c8 --- /dev/null +++ b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/service/equipmentrent/EquipmentrentService.java @@ -0,0 +1,62 @@ +package cn.iocoder.yudao.module.system.service.equipmentrent; + +import java.util.*; +import javax.validation.*; +import cn.iocoder.yudao.module.system.controller.admin.equipmentrent.vo.*; +import cn.iocoder.yudao.module.system.dal.dataobject.equipmentrent.EquipmentrentDO; +import cn.iocoder.yudao.framework.common.pojo.PageResult; +import cn.iocoder.yudao.framework.common.pojo.PageParam; + +/** + * 设备租用 Service 接口 + * + * @author 艾康菲 + */ +public interface EquipmentrentService { + + /** + * 创建设备租用 + * + * @param createReqVO 创建信息 + * @return 编号 + */ + Long createEquipmentrent(@Valid EquipmentrentSaveReqVO createReqVO); + + /** + * 更新设备租用 + * + * @param updateReqVO 更新信息 + */ + void updateEquipmentrent(@Valid EquipmentrentSaveReqVO updateReqVO); + + /** + * 删除设备租用 + * + * @param id 编号 + */ + void deleteEquipmentrent(Long id); + + /** + * 批量删除设备租用 + * + * @param ids 编号 + */ + void deleteEquipmentrentListByIds(List ids); + + /** + * 获得设备租用 + * + * @param id 编号 + * @return 设备租用 + */ + EquipmentrentDO getEquipmentrent(Long id); + + /** + * 获得设备租用分页 + * + * @param pageReqVO 分页查询 + * @return 设备租用分页 + */ + PageResult getEquipmentrentPage(EquipmentrentPageReqVO pageReqVO); + +} \ No newline at end of file diff --git a/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/service/equipmentrent/EquipmentrentServiceImpl.java b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/service/equipmentrent/EquipmentrentServiceImpl.java new file mode 100644 index 0000000..5c57ac2 --- /dev/null +++ b/yudao-module-system/src/main/java/cn/iocoder/yudao/module/system/service/equipmentrent/EquipmentrentServiceImpl.java @@ -0,0 +1,90 @@ +package cn.iocoder.yudao.module.system.service.equipmentrent; + +import cn.hutool.core.collection.CollUtil; +import org.springframework.stereotype.Service; +import javax.annotation.Resource; +import org.springframework.validation.annotation.Validated; +import org.springframework.transaction.annotation.Transactional; + +import java.util.*; +import cn.iocoder.yudao.module.system.controller.admin.equipmentrent.vo.*; +import cn.iocoder.yudao.module.system.dal.dataobject.equipmentrent.EquipmentrentDO; +import cn.iocoder.yudao.framework.common.pojo.PageResult; +import cn.iocoder.yudao.framework.common.pojo.PageParam; +import cn.iocoder.yudao.framework.common.util.object.BeanUtils; + +import cn.iocoder.yudao.module.system.dal.mysql.equipmentrent.EquipmentrentMapper; + +import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception; +import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertList; +import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.diffList; +import static cn.iocoder.yudao.module.system.enums.ErrorCodeConstants.*; + +/** + * 设备租用 Service 实现类 + * + * @author 艾康菲 + */ +@Service +@Validated +public class EquipmentrentServiceImpl implements EquipmentrentService { + + @Resource + private EquipmentrentMapper equipmentrentMapper; + + @Override + public Long createEquipmentrent(EquipmentrentSaveReqVO createReqVO) { + // 插入 + EquipmentrentDO equipmentrent = BeanUtils.toBean(createReqVO, EquipmentrentDO.class); + equipmentrentMapper.insert(equipmentrent); + // 返回 + return equipmentrent.getId(); + } + + @Override + public void updateEquipmentrent(EquipmentrentSaveReqVO updateReqVO) { + // 校验存在 + validateEquipmentrentExists(updateReqVO.getId()); + // 更新 + EquipmentrentDO updateObj = BeanUtils.toBean(updateReqVO, EquipmentrentDO.class); + equipmentrentMapper.updateById(updateObj); + } + + @Override + public void deleteEquipmentrent(Long id) { + // 校验存在 + validateEquipmentrentExists(id); + // 删除 + equipmentrentMapper.deleteById(id); + } + + @Override + public void deleteEquipmentrentListByIds(List ids) { + // 校验存在 + validateEquipmentrentExists(ids); + // 删除 + equipmentrentMapper.deleteByIds(ids); + } + + private void validateEquipmentrentExists(List ids) { + List list = equipmentrentMapper.selectByIds(ids); + if (CollUtil.isEmpty(list) || list.size() != ids.size()) { + } + } + + private void validateEquipmentrentExists(Long id) { + if (equipmentrentMapper.selectById(id) == null) { + } + } + + @Override + public EquipmentrentDO getEquipmentrent(Long id) { + return equipmentrentMapper.selectById(id); + } + + @Override + public PageResult getEquipmentrentPage(EquipmentrentPageReqVO pageReqVO) { + return equipmentrentMapper.selectPage(pageReqVO); + } + +} \ No newline at end of file diff --git a/yudao-module-system/src/main/resources/mapper/equipmentrent/EquipmentrentMapper.xml b/yudao-module-system/src/main/resources/mapper/equipmentrent/EquipmentrentMapper.xml new file mode 100644 index 0000000..f6f4e3b --- /dev/null +++ b/yudao-module-system/src/main/resources/mapper/equipmentrent/EquipmentrentMapper.xml @@ -0,0 +1,12 @@ + + + + + + + \ No newline at end of file diff --git a/yudao-server/src/main/resources/application.yaml b/yudao-server/src/main/resources/application.yaml index 13ac048..785e262 100644 --- a/yudao-server/src/main/resources/application.yaml +++ b/yudao-server/src/main/resources/application.yaml @@ -309,6 +309,7 @@ yudao: - tb_ecgconfig #忽略心电工作站配置表 - tb_hrv #忽略精神压力患者表 - tb_hrvdata #忽略精神压力数据表 + - tb_equipmentrent #忽略设备租赁表 ignore-caches: - user_role_ids - permission_menu_ids