eight
2024-08-12 613977d01ffaabfbd638b200428f4f0e84f888d4
新增 门诊室 配置
已添加9个文件
已修改2个文件
432 ■■■■■ 文件已修改
jh-module-ecg/jh-module-ecg-api/src/main/java/cn/lihu/jh/module/ecg/enums/ErrorCodeConstants.java 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/room/RoomController.java 99 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/room/vo/RoomPageReqVO.java 28 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/room/vo/RoomRespVO.java 31 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/room/vo/RoomSaveReqVO.java 24 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/dataobject/room/RoomDO.java 39 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/room/RoomMapper.java 29 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/room/RoomService.java 57 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/room/RoomServiceImpl.java 76 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/resources/mapper/room/RoomMapper.xml 12 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
sql/mysql/jh.sql 35 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-api/src/main/java/cn/lihu/jh/module/ecg/enums/ErrorCodeConstants.java
@@ -10,5 +10,5 @@
public interface ErrorCodeConstants {
    ErrorCode APPOINTMENT_NOT_EXISTS = new ErrorCode(1_010_000_000, "预约不存在");
    ErrorCode ROOM_NOT_EXISTS = new ErrorCode(1_010_000_001, "诊室和诊疗床不存在");
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/room/RoomController.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,99 @@
package cn.lihu.jh.module.ecg.controller.admin.room;
import cn.lihu.jh.module.ecg.controller.admin.room.vo.RoomPageReqVO;
import cn.lihu.jh.module.ecg.controller.admin.room.vo.RoomRespVO;
import cn.lihu.jh.module.ecg.controller.admin.room.vo.RoomSaveReqVO;
import cn.lihu.jh.module.ecg.dal.dataobject.room.RoomDO;
import cn.lihu.jh.module.ecg.service.room.RoomService;
import org.springframework.web.bind.annotation.*;
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 java.util.*;
import java.io.IOException;
import cn.lihu.jh.framework.common.pojo.PageParam;
import cn.lihu.jh.framework.common.pojo.PageResult;
import cn.lihu.jh.framework.common.pojo.CommonResult;
import cn.lihu.jh.framework.common.util.object.BeanUtils;
import static cn.lihu.jh.framework.common.pojo.CommonResult.success;
import cn.lihu.jh.framework.excel.core.util.ExcelUtils;
import cn.lihu.jh.framework.apilog.core.annotation.ApiAccessLog;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import static cn.lihu.jh.framework.apilog.core.enums.OperateTypeEnum.*;
@Tag(name = "管理后台 - è¯Šå®¤å’Œè¯Šç–—床")
@RestController
@RequestMapping("/clinic/room")
@Validated
public class RoomController {
    @Resource
    private RoomService roomService;
    @PostMapping("/create")
    @Operation(summary = "创建诊室和诊疗床")
    @PreAuthorize("@ss.hasPermission('clinic:room:create')")
    public CommonResult<Integer> createRoom(@Valid @RequestBody RoomSaveReqVO createReqVO) {
        return success(roomService.createRoom(createReqVO));
    }
    @PutMapping("/update")
    @Operation(summary = "更新诊室和诊疗床")
    @PreAuthorize("@ss.hasPermission('clinic:room:update')")
    public CommonResult<Boolean> updateRoom(@Valid @RequestBody RoomSaveReqVO updateReqVO) {
        roomService.updateRoom(updateReqVO);
        return success(true);
    }
    @DeleteMapping("/delete")
    @Operation(summary = "删除诊室和诊疗床")
    @Parameter(name = "id", description = "编号", required = true)
    @PreAuthorize("@ss.hasPermission('clinic:room:delete')")
    public CommonResult<Boolean> deleteRoom(@RequestParam("id") Integer id) {
        roomService.deleteRoom(id);
        return success(true);
    }
    @GetMapping("/get")
    @Operation(summary = "获得诊室和诊疗床")
    @Parameter(name = "id", description = "编号", required = true, example = "1024")
    @PreAuthorize("@ss.hasPermission('clinic:room:query')")
    public CommonResult<RoomRespVO> getRoom(@RequestParam("id") Integer id) {
        RoomDO room = roomService.getRoom(id);
        return success(BeanUtils.toBean(room, RoomRespVO.class));
    }
    @GetMapping("/page")
    @Operation(summary = "获得诊室和诊疗床分页")
    @PreAuthorize("@ss.hasPermission('clinic:room:query')")
    public CommonResult<PageResult<RoomRespVO>> getRoomPage(@Valid RoomPageReqVO pageReqVO) {
        PageResult<RoomDO> pageResult = roomService.getRoomPage(pageReqVO);
        return success(BeanUtils.toBean(pageResult, RoomRespVO.class));
    }
    @GetMapping("/export-excel")
    @Operation(summary = "导出诊室和诊疗床 Excel")
    @PreAuthorize("@ss.hasPermission('clinic:room:export')")
    @ApiAccessLog(operateType = EXPORT)
    public void exportRoomExcel(@Valid RoomPageReqVO pageReqVO,
              HttpServletResponse response) throws IOException {
        pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
        List<RoomDO> list = roomService.getRoomPage(pageReqVO).getList();
        // å¯¼å‡º Excel
        ExcelUtils.write(response, "诊室和诊疗床.xls", "数据", RoomRespVO.class,
                        BeanUtils.toBean(list, RoomRespVO.class));
    }
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/room/vo/RoomPageReqVO.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,28 @@
package cn.lihu.jh.module.ecg.controller.admin.room.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import cn.lihu.jh.framework.common.pojo.PageParam;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import static cn.lihu.jh.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
@Schema(description = "管理后台 - è¯Šå®¤å’Œè¯Šç–—床分页 Request VO")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
public class RoomPageReqVO extends PageParam {
    @Schema(description = "诊室编号")
    private String roomNo;
    @Schema(description = "诊疗床编号")
    private String bedNo;
    @Schema(description = "创建时间")
    @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
    private LocalDateTime[] createTime;
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/room/vo/RoomRespVO.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,31 @@
package cn.lihu.jh.module.ecg.controller.admin.room.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 RoomRespVO {
    @Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("编号")
    private Integer id;
    @Schema(description = "诊室编号", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("诊室编号")
    private String roomNo;
    @Schema(description = "诊疗床编号", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("诊疗床编号")
    private String bedNo;
    @Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("创建时间")
    private LocalDateTime createTime;
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/room/vo/RoomSaveReqVO.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,24 @@
package cn.lihu.jh.module.ecg.controller.admin.room.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import javax.validation.constraints.NotEmpty;
import java.util.*;
@Schema(description = "管理后台 - è¯Šå®¤å’Œè¯Šç–—床新增/修改 Request VO")
@Data
public class RoomSaveReqVO {
    private Integer id;
    @Schema(description = "诊室编号", requiredMode = Schema.RequiredMode.REQUIRED)
    @NotEmpty(message = "诊室编号不能为空")
    private String roomNo;
    @Schema(description = "诊疗床编号", requiredMode = Schema.RequiredMode.REQUIRED)
    @NotEmpty(message = "诊疗床编号不能为空")
    private String bedNo;
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/dataobject/room/RoomDO.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,39 @@
package cn.lihu.jh.module.ecg.dal.dataobject.room;
import lombok.*;
import java.util.*;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import com.baomidou.mybatisplus.annotation.*;
import cn.lihu.jh.framework.mybatis.core.dataobject.BaseDO;
/**
 * è¯Šå®¤å’Œè¯Šç–—床 DO
 *
 * @author èŠ‹é“æºç 
 */
@TableName("clinic_room")
@KeySequence("clinic_room_seq") // ç”¨äºŽ Oracle、PostgreSQL、Kingbase、DB2、H2 æ•°æ®åº“的主键自增。如果是 MySQL ç­‰æ•°æ®åº“,可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class RoomDO extends BaseDO {
    /**
     * id
     */
    @TableId
    private Integer id;
    /**
     * è¯Šå®¤ç¼–号
     */
    private String roomNo;
    /**
     * è¯Šç–—床编号
     */
    private String bedNo;
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/room/RoomMapper.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,29 @@
package cn.lihu.jh.module.ecg.dal.mysql.room;
import java.util.*;
import cn.lihu.jh.framework.common.pojo.PageResult;
import cn.lihu.jh.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.lihu.jh.framework.mybatis.core.mapper.BaseMapperX;
import cn.lihu.jh.module.ecg.controller.admin.room.vo.RoomPageReqVO;
import cn.lihu.jh.module.ecg.dal.dataobject.room.RoomDO;
import org.apache.ibatis.annotations.Mapper;
/**
 * è¯Šå®¤å’Œè¯Šç–—床 Mapper
 *
 * @author èŠ‹é“æºç 
 */
@Mapper
public interface RoomMapper extends BaseMapperX<RoomDO> {
    default PageResult<RoomDO> selectPage(RoomPageReqVO reqVO) {
        return selectPage(reqVO, new LambdaQueryWrapperX<RoomDO>()
                .eqIfPresent(RoomDO::getRoomNo, reqVO.getRoomNo())
                .eqIfPresent(RoomDO::getBedNo, reqVO.getBedNo())
                .betweenIfPresent(RoomDO::getCreateTime, reqVO.getCreateTime())
                .orderByDesc(RoomDO::getId));
    }
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/room/RoomService.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,57 @@
package cn.lihu.jh.module.ecg.service.room;
import java.util.*;
import cn.lihu.jh.framework.common.pojo.PageResult;
import cn.lihu.jh.framework.common.pojo.PageParam;
import cn.lihu.jh.module.ecg.controller.admin.room.vo.RoomPageReqVO;
import cn.lihu.jh.module.ecg.controller.admin.room.vo.RoomSaveReqVO;
import cn.lihu.jh.module.ecg.dal.dataobject.room.RoomDO;
import javax.validation.Valid;
/**
 * è¯Šå®¤å’Œè¯Šç–—床 Service æŽ¥å£
 *
 * @author èŠ‹é“æºç 
 */
public interface RoomService {
    /**
     * åˆ›å»ºè¯Šå®¤å’Œè¯Šç–—床
     *
     * @param createReqVO åˆ›å»ºä¿¡æ¯
     * @return ç¼–号
     */
    Integer createRoom(@Valid RoomSaveReqVO createReqVO);
    /**
     * æ›´æ–°è¯Šå®¤å’Œè¯Šç–—床
     *
     * @param updateReqVO æ›´æ–°ä¿¡æ¯
     */
    void updateRoom(@Valid RoomSaveReqVO updateReqVO);
    /**
     * åˆ é™¤è¯Šå®¤å’Œè¯Šç–—床
     *
     * @param id ç¼–号
     */
    void deleteRoom(Integer id);
    /**
     * èŽ·å¾—è¯Šå®¤å’Œè¯Šç–—åºŠ
     *
     * @param id ç¼–号
     * @return è¯Šå®¤å’Œè¯Šç–—床
     */
    RoomDO getRoom(Integer id);
    /**
     * èŽ·å¾—è¯Šå®¤å’Œè¯Šç–—åºŠåˆ†é¡µ
     *
     * @param pageReqVO åˆ†é¡µæŸ¥è¯¢
     * @return è¯Šå®¤å’Œè¯Šç–—床分页
     */
    PageResult<RoomDO> getRoomPage(RoomPageReqVO pageReqVO);
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/room/RoomServiceImpl.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,76 @@
package cn.lihu.jh.module.ecg.service.room;
import cn.lihu.jh.module.ecg.controller.admin.room.vo.RoomPageReqVO;
import cn.lihu.jh.module.ecg.controller.admin.room.vo.RoomSaveReqVO;
import cn.lihu.jh.module.ecg.dal.dataobject.room.RoomDO;
import cn.lihu.jh.module.ecg.dal.mysql.room.RoomMapper;
import org.springframework.stereotype.Service;
import org.springframework.validation.annotation.Validated;
import org.springframework.transaction.annotation.Transactional;
import java.util.*;
import cn.lihu.jh.framework.common.pojo.PageResult;
import cn.lihu.jh.framework.common.pojo.PageParam;
import cn.lihu.jh.framework.common.util.object.BeanUtils;
import javax.annotation.Resource;
import static cn.lihu.jh.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.lihu.jh.module.ecg.enums.ErrorCodeConstants.ROOM_NOT_EXISTS;
/**
 * è¯Šå®¤å’Œè¯Šç–—床 Service å®žçŽ°ç±»
 *
 * @author èŠ‹é“æºç 
 */
@Service
@Validated
public class RoomServiceImpl implements RoomService {
    @Resource
    private RoomMapper roomMapper;
    @Override
    public Integer createRoom(RoomSaveReqVO createReqVO) {
        // æ’å…¥
        RoomDO room = BeanUtils.toBean(createReqVO, RoomDO.class);
        roomMapper.insert(room);
        // è¿”回
        return room.getId();
    }
    @Override
    public void updateRoom(RoomSaveReqVO updateReqVO) {
        // æ ¡éªŒå­˜åœ¨
        validateRoomExists(updateReqVO.getId());
        // æ›´æ–°
        RoomDO updateObj = BeanUtils.toBean(updateReqVO, RoomDO.class);
        roomMapper.updateById(updateObj);
    }
    @Override
    public void deleteRoom(Integer id) {
        // æ ¡éªŒå­˜åœ¨
        validateRoomExists(id);
        // åˆ é™¤
        roomMapper.deleteById(id);
    }
    private void validateRoomExists(Integer id) {
        if (roomMapper.selectById(id) == null) {
            throw exception(ROOM_NOT_EXISTS);
        }
    }
    @Override
    public RoomDO getRoom(Integer id) {
        return roomMapper.selectById(id);
    }
    @Override
    public PageResult<RoomDO> getRoomPage(RoomPageReqVO pageReqVO) {
        return roomMapper.selectPage(pageReqVO);
    }
}
jh-module-ecg/jh-module-ecg-biz/src/main/resources/mapper/room/RoomMapper.xml
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.lihu.jh.module.clinic.dal.mysql.room.RoomMapper">
    <!--
        ä¸€èˆ¬æƒ…况下,尽可能使用 Mapper è¿›è¡Œ CRUD å¢žåˆ æ”¹æŸ¥å³å¯ã€‚
        æ— æ³•满足的场景,例如说多表关联查询,才使用 XML ç¼–写 SQL。
        ä»£ç ç”Ÿæˆå™¨æš‚时只生成 Mapper XML æ–‡ä»¶æœ¬èº«ï¼Œæ›´å¤šæŽ¨è MybatisX å¿«é€Ÿå¼€å‘插件来生成查询。
        æ–‡æ¡£å¯è§ï¼šhttps://www.iocoder.cn/MyBatis/x-plugins/
     -->
</mapper>
sql/mysql/jh.sql
@@ -28,12 +28,12 @@
  `book_check_type` tinyint(1) DEFAULT NULL COMMENT '预约检查类型',
  `book_src` tinyint(1) NOT NULL COMMENT '预约来源:X系统、护士手动预约',
  `sync_time` datetime DEFAULT NULL COMMENT '从数据平台同步时间',
  `tenant_id` int NOT NULL COMMENT '租户编号',
  `creator` varchar(10) DEFAULT '' COMMENT '创建者',
  `create_time` datetime NOT NULL COMMENT '创建时间',
  `updater` varchar(10) DEFAULT '' COMMENT '更新者',
  `update_time` datetime NOT NULL COMMENT '更新时间',
  `deleted` bit(1) DEFAULT 0 COMMENT '删除标记',
  `tenant_id` bigint NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='预约表';
@@ -56,26 +56,31 @@
  `expired` tinyint(1) NOT NULL COMMENT '预约过期标记',
  `room_num` varchar(10) DEFAULT NULL COMMENT '诊室编号',
  `bed_num` varchar(10) DEFAULT NULL COMMENT '诊疗床编号',
  `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  `update_time` datetime DEFAULT NULL COMMENT '更新时间',
  `tenant_id` bigint NOT NULL,
  `tenant_id` int NOT NULL COMMENT '租户编号',
  `creator` varchar(10) DEFAULT '' COMMENT '创建者',
  `create_time` datetime NOT NULL COMMENT '创建时间',
  `updater` varchar(10) DEFAULT '' COMMENT '更新者',
  `update_time` datetime NOT NULL COMMENT '更新时间',
  `deleted` bit(1) DEFAULT 0 COMMENT '删除标记',
  PRIMARY KEY (`id`),
  UNIQUE KEY `idx_seq_id` (`seq_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='排队表';
-- ----------------------------
-- Table structure for room_bed
-- Table structure for clinic_room
-- ----------------------------
DROP TABLE IF EXISTS `room_bed`;
CREATE TABLE `room_bed` (
DROP TABLE IF EXISTS `clinic_room`;
CREATE TABLE `clinic_room` (
  `id` int NOT NULL AUTO_INCREMENT COMMENT 'id',
  `room_no` varchar(10) NOT NULL COMMENT '诊室编号',
  `bed_no` varchar(10) NOT NULL COMMENT '诊疗床编号',
  `tenant_id` int NOT NULL COMMENT '租户编号',
  `creator` varchar(10) DEFAULT '' COMMENT '创建者',
  `create_time` datetime NOT NULL COMMENT '创建时间',
  `updater` varchar(10) DEFAULT '' COMMENT '更新者',
  `update_time` datetime NOT NULL COMMENT '更新时间',
  `deleted` bit(1) DEFAULT NULL COMMENT '删除标记',
  `tenant_id` bigint NOT NULL,
  `deleted` bit(1) DEFAULT 0 COMMENT '删除标记',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='诊室和诊疗床表';
@@ -89,10 +94,10 @@
  `category` varchar(45) DEFAULT NULL COMMENT '分类名',
  `brand` varchar(45) DEFAULT NULL COMMENT '品牌',
  `model` varchar(45) DEFAULT NULL COMMENT '型号',
  `tenant_id` int NOT NULL COMMENT '租户编号',
  `create_time` datetime NOT NULL COMMENT '创建时间',
  `update_time` datetime NOT NULL COMMENT '更新时间',
  `deleted` bit(1) DEFAULT NULL COMMENT '删除标记',
  `tenant_id` bigint NOT NULL,
  `deleted` bit(1) DEFAULT 0 COMMENT '删除标记',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='设备型号表';
@@ -108,10 +113,10 @@
  `brand` varchar(45) DEFAULT NULL COMMENT '品牌',
  `model` varchar(45) DEFAULT NULL COMMENT '型号',
  `purchase_date` date DEFAULT NULL COMMENT '采购日期',
  `tenant_id` int NOT NULL COMMENT '租户编号',
  `create_time` datetime NOT NULL COMMENT '创建时间',
  `update_time` datetime NOT NULL COMMENT '更新时间',
  `deleted` bit(1) DEFAULT NULL COMMENT '删除标记',
  `tenant_id` bigint NOT NULL,
  `deleted` bit(1) DEFAULT 0 COMMENT '删除标记',
  PRIMARY KEY (`id`),
  UNIQUE KEY `dev_id_UNIQUE` (`dev_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='设备表';
@@ -132,10 +137,10 @@
  `baseline` varchar(100) DEFAULT NULL COMMENT '基线粗',
  `detachment` varchar(100) DEFAULT NULL COMMENT '脱离',  
  `remark` varchar(100) DEFAULT NULL COMMENT '备注',
  `tenant_id` int NOT NULL COMMENT '租户编号',
  `create_time` datetime NOT NULL COMMENT '创建时间',
  `update_time` datetime NOT NULL COMMENT '更新时间',
  `deleted` bit(1) DEFAULT NULL,
  `tenant_id` bigint NOT NULL,
  `deleted` bit(1) DEFAULT 0,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='装机拆机表';