pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoIr/IrGroupUnitMapper.java
New file @@ -0,0 +1,28 @@ package com.dy.pipIrrGlobal.daoIr; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.dy.pipIrrGlobal.pojoIr.IrGroupUnit; import com.dy.pipIrrGlobal.pojoIr.IrIrrigateGroup; import org.apache.ibatis.annotations.Mapper; /** * @author :WuZeYu * @Date :2024/5/22 13:41 * @LastEditTime :2024/5/22 13:41 * @Description */ @Mapper public interface IrGroupUnitMapper extends BaseMapper<IrGroupUnit> { //增 int insertSelective(IrGroupUnit record); //删 int deleteLogicById(Long id); //删by unitId groupId int deleteByUnitIdGroupId(IrGroupUnit record); //删by unitId int deleteByUnitId(Long unitId); //删by groupId int deleteByGroupId(Long groupId); } pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoIr/IrIrrigateGroupMapper.java
New file @@ -0,0 +1,50 @@ package com.dy.pipIrrGlobal.daoIr; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.dy.pipIrrGlobal.pojoIr.IrIrrigateGroup; import com.dy.pipIrrGlobal.pojoIr.IrIrrigateUnit; import com.dy.pipIrrGlobal.voIr.VoGroup; import com.dy.pipIrrGlobal.voIr.VoGroupOne; import com.dy.pipIrrGlobal.voIr.VoUnit; import com.dy.pipIrrGlobal.voIr.VoUnitOne; import org.apache.ibatis.annotations.Mapper; import java.util.List; import java.util.Map; /** * @author :WuZeYu * @Date :2024/5/21 15:32 * @LastEditTime :2024/5/21 15:32 * @Description */ @Mapper public interface IrIrrigateGroupMapper extends BaseMapper<IrIrrigateGroup> { //增 int insertSelective(IrIrrigateGroup record); //删 int deleteLogicById(Long id); //改 int updateByPrimaryKeySelective(IrIrrigateGroup record); //查一个 VoGroupOne selectById(Long id); /** * 根据指定条件获取取水口记录数 * * @param params * @return */ Long getRecordCount(Map<?, ?> params); /** * 根据指定条件获取取水口记录 * * @param params * @return */ List<VoGroup> getIrrigateGroups(Map<?, ?> params); } pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoIr/IrGroupUnit.java
New file @@ -0,0 +1,77 @@ package com.dy.pipIrrGlobal.pojoIr; import com.alibaba.fastjson2.annotation.JSONField; import com.alibaba.fastjson2.writer.ObjectWriterImplToString; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableId; import com.baomidou.mybatisplus.annotation.TableName; import com.dy.common.po.BaseEntity; import io.swagger.v3.oas.annotations.media.Schema; import jakarta.validation.constraints.NotNull; import lombok.*; import java.util.Date; /** * @author :WuZeYu * @Date :2024/5/22 13:43 * @LastEditTime :2024/5/22 13:43 * @Description */ /** * 轮灌组灌溉单元中间表 */ @TableName(value="ir_group_unit", autoResultMap = true) @Data @Builder @ToString @NoArgsConstructor @AllArgsConstructor @Schema(name = "轮灌组灌溉单元中间表实体") public class IrGroupUnit implements BaseEntity { public static final long serialVersionUID = 202405221354001L; /** * 主键 */ @JSONField(serializeUsing= ObjectWriterImplToString.class) @TableId(type = IdType.INPUT) @Schema(description = "实体id", requiredMode = Schema.RequiredMode.NOT_REQUIRED) private Long id; /** * 轮灌组ID */ @Schema(description = "轮灌组ID", requiredMode = Schema.RequiredMode.REQUIRED) @NotNull(message = "轮灌组ID不能为空") private Long groupId; /** * 灌溉单元ID */ @Schema(description = "灌溉单元ID", requiredMode = Schema.RequiredMode.REQUIRED) @NotNull(message = "灌溉单元ID不能为空") private Long unitId; /** * 操作人ID */ @Schema(description = "操作人ID", requiredMode = Schema.RequiredMode.NOT_REQUIRED) @NotNull(message = "操作人ID不能为空") private Long operator; /** * 操作时间 */ @Schema(description = "操作时间", requiredMode = Schema.RequiredMode.NOT_REQUIRED) private Date operateDt; /** * 逻辑删除标识;0-未删除,1-删除 */ @Schema(description = "删除标识", requiredMode = Schema.RequiredMode.NOT_REQUIRED) private Byte deleted; } pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoIr/IrIrrigateGroup.java
New file @@ -0,0 +1,84 @@ package com.dy.pipIrrGlobal.pojoIr; import com.alibaba.fastjson2.annotation.JSONField; import com.alibaba.fastjson2.writer.ObjectWriterImplToString; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableId; import com.baomidou.mybatisplus.annotation.TableName; import com.dy.common.po.BaseEntity; import io.swagger.v3.oas.annotations.media.Schema; import jakarta.validation.constraints.NotNull; import lombok.*; import org.apache.logging.log4j.core.config.plugins.validation.constraints.NotBlank; import java.util.Date; /** * @author :WuZeYu * @Date :2024/5/21 15:34 * @LastEditTime :2024/5/21 15:34 * @Description */ /** * 轮灌组表 */ @TableName(value="ir_irrigate_group", autoResultMap = true) @Data @Builder @ToString @NoArgsConstructor @AllArgsConstructor @Schema(name = "轮灌组实体") public class IrIrrigateGroup implements BaseEntity { public static final long serialVersionUID = 202405211534001L; /** * 主键 */ @JSONField(serializeUsing= ObjectWriterImplToString.class) @TableId(type = IdType.INPUT) @Schema(description = "实体id", requiredMode = Schema.RequiredMode.NOT_REQUIRED) private Long id; /** * 轮灌组编码 */ @Schema(description = "轮灌组编码", requiredMode = Schema.RequiredMode.REQUIRED) @NotBlank(message = "轮灌组编码不能为空") private String groupCode; /** * 项目ID */ @Schema(description = "项目ID", requiredMode = Schema.RequiredMode.REQUIRED) @NotNull(message = "项目ID不能为空") private Long projectId; /** * 备注 */ @Schema(description = "备注", requiredMode = Schema.RequiredMode.REQUIRED) private String remarks; /** * 操作人ID */ @Schema(description = "操作人ID", requiredMode = Schema.RequiredMode.NOT_REQUIRED) @NotNull(message = "操作人ID不能为空") private Long operator; /** * 操作时间 */ @Schema(description = "操作时间", requiredMode = Schema.RequiredMode.NOT_REQUIRED) private Date operateDt; /** * 逻辑删除标识;0-未删除,1-删除 */ @Schema(description = "删除标识", requiredMode = Schema.RequiredMode.NOT_REQUIRED) private Byte deleted; } pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voIr/VoGroup.java
New file @@ -0,0 +1,51 @@ package com.dy.pipIrrGlobal.voIr; import com.dy.common.po.BaseEntity; import io.swagger.v3.oas.annotations.media.Schema; import lombok.Data; import java.util.Date; /** * @author :WuZeYu * @Date :2024/5/21 16:34 * @LastEditTime :2024/5/21 16:34 * @Description */ @Data @Schema(name = "轮灌组视图") public class VoGroup implements BaseEntity { @Schema(description = "所属项目名称") public String projectName; @Schema(description = "轮灌组编码") private String groupCode; @Schema(description = "灌溉单元数量") private Integer itemCount; @Schema(description = "轮灌组ID") private String id; @Schema(description = "备注") private String remarks; @Schema(description = "所属项目Id") public String projectId; /** * 操作人名字 */ @Schema(description = "操作人名字") private String operatorName; @Schema(description = "操作人Id") private String operator; /** * 操作时间 */ @Schema(description = "操作时间") private Date operateDt; } pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voIr/VoGroupOne.java
New file @@ -0,0 +1,51 @@ package com.dy.pipIrrGlobal.voIr; import com.dy.common.po.BaseEntity; import io.swagger.v3.oas.annotations.media.Schema; import lombok.Data; import java.util.Date; /** * @author :WuZeYu * @Date :2024/5/21 16:34 * @LastEditTime :2024/5/21 16:34 * @Description */ @Data @Schema(name = "轮灌组视图(查一个)") public class VoGroupOne implements BaseEntity { @Schema(description = "所属项目名称") public String projectName; @Schema(description = "轮灌组编码") private String groupCode; @Schema(description = "灌溉单元数量") private Integer itemCount; @Schema(description = "轮灌组ID") private String id; @Schema(description = "备注") private String remarks; @Schema(description = "所属项目Id") public String projectId; /** * 操作人名字 */ @Schema(description = "操作人名字") private String operatorName; @Schema(description = "操作人Id") private String operator; /** * 操作时间 */ @Schema(description = "操作时间") private Date operateDt; } pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrGroupUnitMapper.xml
New file @@ -0,0 +1,91 @@ <?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="com.dy.pipIrrGlobal.daoIr.IrGroupUnitMapper"> <resultMap id="BaseResultMap" type="com.dy.pipIrrGlobal.pojoIr.IrGroupUnit"> <!--@mbg.generated--> <!--@Table ir_group_unit--> <id column="id" jdbcType="BIGINT" property="id" /> <result column="group_id" jdbcType="BIGINT" property="groupId" /> <result column="unit_id" jdbcType="BIGINT" property="unitId" /> <result column="operator" jdbcType="BIGINT" property="operator" /> <result column="operate_time" jdbcType="TIMESTAMP" property="operateDt" /> <result column="deleted" jdbcType="TINYINT" property="deleted" /> </resultMap> <sql id="Base_Column_List"> <!--@mbg.generated--> id, group_id, unit_id, `operator`, operate_time, deleted </sql> <!--添加--> <insert id="insertSelective" parameterType="com.dy.pipIrrGlobal.pojoIr.IrGroupUnit"> <!--@mbg.generated--> insert into ir_group_unit <trim prefix="(" suffix=")" suffixOverrides=","> <if test="id != null"> id, </if> <if test="groupId != null"> group_id, </if> <if test="unitId != null"> unit_id, </if> <if test="operator != null"> `operator`, </if> <if test="operateDt != null"> operate_time, </if> <if test="deleted != null"> deleted, </if> </trim> <trim prefix="values (" suffix=")" suffixOverrides=","> <if test="id != null"> #{id,jdbcType=BIGINT}, </if> <if test="groupId != null"> #{groupId,jdbcType=BIGINT}, </if> <if test="unitId != null"> #{unitId,jdbcType=BIGINT}, </if> <if test="operator != null"> #{operator,jdbcType=BIGINT}, </if> <if test="operateDt != null"> #{operateDt,jdbcType=TIMESTAMP}, </if> <if test="deleted != null"> #{deleted,jdbcType=TINYINT}, </if> </trim> </insert> <!--逻辑删除--> <delete id="deleteLogicById" parameterType="java.lang.Long"> <!--@mbg.generated--> update ir_group_unit set deleted = 1 where id = #{id,jdbcType=BIGINT} </delete> <delete id="deleteByUnitIdGroupId" parameterType="com.dy.pipIrrGlobal.pojoIr.IrGroupUnit"> update ir_group_unit set deleted = 1,operator = #{operator,jdbcType=BIGINT},operate_time = #{operateDt,jdbcType=TIMESTAMP} where group_id = #{groupId,jdbcType=BIGINT} and unit_id = #{unitId,jdbcType=BIGINT} </delete> <delete id="deleteByUnitId"> update ir_group_unit set deleted = 1 where unit_id = #{unitId,jdbcType=BIGINT} </delete> <delete id="deleteByGroupId"> update ir_group_unit set deleted = 1 where group_id = #{groupId,jdbcType=BIGINT} </delete> </mapper> pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigateGroupMapper.xml
New file @@ -0,0 +1,172 @@ <?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="com.dy.pipIrrGlobal.daoIr.IrIrrigateGroupMapper"> <resultMap id="BaseResultMap" type="com.dy.pipIrrGlobal.pojoIr.IrIrrigateGroup"> <!--@mbg.generated--> <!--@Table ir_irrigate_group--> <id column="id" jdbcType="BIGINT" property="id" /> <result column="project_id" jdbcType="BIGINT" property="projectId" /> <result column="group_code" jdbcType="VARCHAR" property="groupCode" /> <result column="remarks" jdbcType="VARCHAR" property="remarks" /> <result column="operator" jdbcType="BIGINT" property="operator" /> <result column="operate_time" jdbcType="TIMESTAMP" property="operateDt" /> <result column="deleted" jdbcType="TINYINT" property="deleted" /> </resultMap> <sql id="Base_Column_List"> <!--@mbg.generated--> id, project_id, group_code, remarks, `operator`, operate_time, deleted </sql> <!--添加--> <insert id="insertSelective" parameterType="com.dy.pipIrrGlobal.pojoIr.IrIrrigateGroup"> <!--@mbg.generated--> insert into ir_irrigate_group <trim prefix="(" suffix=")" suffixOverrides=","> <if test="id != null"> id, </if> <if test="projectId != null"> project_id, </if> <if test="groupCode != null"> group_code, </if> <if test="remarks != null"> remarks, </if> <if test="operator != null"> `operator`, </if> <if test="operateDt != null"> operate_time, </if> <if test="deleted != null"> deleted, </if> </trim> <trim prefix="values (" suffix=")" suffixOverrides=","> <if test="id != null"> #{id,jdbcType=BIGINT}, </if> <if test="projectId != null"> #{projectId,jdbcType=BIGINT}, </if> <if test="groupCode != null"> #{groupCode,jdbcType=VARCHAR}, </if> <if test="remarks != null"> #{remarks,jdbcType=VARCHAR}, </if> <if test="operator != null"> #{operator,jdbcType=BIGINT}, </if> <if test="operateDt != null"> #{operateDt,jdbcType=TIMESTAMP}, </if> <if test="deleted != null"> #{deleted,jdbcType=TINYINT}, </if> </trim> </insert> <!--逻辑删除--> <delete id="deleteLogicById" parameterType="java.lang.Long"> <!--@mbg.generated--> update ir_irrigate_group set deleted = 1 where id = #{id,jdbcType=BIGINT} </delete> <!--修改一个轮罐组--> <update id="updateByPrimaryKeySelective" parameterType="com.dy.pipIrrGlobal.pojoIr.IrIrrigateGroup"> update ir_irrigate_group <set> <if test="projectId != null"> project_id = #{projectId,jdbcType=BIGINT}, </if> <if test="groupCode != null"> group_code = #{groupCode,jdbcType=VARCHAR}, </if> <if test="remarks != null"> remarks = #{remarks,jdbcType=VARCHAR}, </if> <if test="operator != null"> operator = #{operator,jdbcType=BIGINT}, </if> <if test="operateDt != null"> operate_time = #{operateDt,jdbcType=TIMESTAMP}, </if> <if test="deleted != null"> deleted = #{deleted,jdbcType=TINYINT}, </if> </set> where id = #{id,jdbcType=BIGINT} </update> <!--查一个轮罐组--> <select id="selectById" resultType="com.dy.pipIrrGlobal.voIr.VoGroupOne"> select CAST(pro.id AS char)AS projectId, pro.project_name AS projectName, CAST(gro.id AS char)AS id, CAST(gro.operator AS char)AS operator, cli.name AS operatorName, gro.group_code AS groupCode, COUNT(gu.group_id) AS itemCount, gro.remarks, gro.operate_time AS operateDt from ir_irrigate_group gro left join ir_project pro on pro.id = gro.project_id left join se_client cli on cli.id = gro.operator left join ir_group_unit gu on gu.group_id = gro.id where gro.id = #{id,jdbcType=BIGINT} and gro.deleted = 0 and gu.deleted = 0 and pro.deleted = 0 </select> <!--分页查轮灌组--> <select id="getIrrigateGroups" resultType="com.dy.pipIrrGlobal.voIr.VoGroup"> SELECT CAST(pro.id AS char)AS projectId, pro.project_name AS projectName, CAST(gro.id AS char)AS id, CAST(gro.operator AS char)AS operator, cli.name AS operatorName, gro.group_code AS groupCode, COUNT(gu.group_id) AS itemCount, gro.remarks, gro.operate_time AS operateDt from ir_irrigate_group gro left join ir_project pro on pro.id = gro.project_id left join se_client cli on cli.id = gro.operator left join ir_group_unit gu on gu.group_id = gro.id <where> gro.deleted = 0 and gu.deleted = 0 and pro.deleted = 0 <if test="projectName != null and projectName != ''"> AND pro.project_name LIKE CONCAT('%', #{projectName}, '%') </if> <if test="groupCode != null and groupCode != ''"> AND gro.group_code = #{groupCode} </if> </where> ORDER BY gro.operate_time DESC <if test="pageCurr != null and pageSize != null"> LIMIT ${(pageCurr-1)*pageSize}, ${pageSize} </if> </select> <!--分页查轮灌组记录数--> <select id="getRecordCount" resultType="java.lang.Long"> SELECT COUNT(*) AS recordCount from ir_irrigate_group gro left join ir_project pro on pro.id = gro.project_id left join se_client cli on cli.id = gro.operator left join ir_group_unit gu on gu.group_id = gro.id <where> gro.deleted = 0 and gu.deleted = 0 and pro.deleted = 0 <if test="projectName != null and projectName != ''"> AND pro.project_name LIKE CONCAT('%', #{projectName}, '%') </if> <if test="groupCode != null and groupCode != ''"> AND gro.group_code = #{groupCode} </if> </where> </select> </mapper> pipIrr-platform/pipIrr-web/pipIrr-web-irrigate/src/main/java/com/dy/pipIrrIrrigate/irrigateGroup/IrrigateGroupCtrl.java
New file @@ -0,0 +1,301 @@ package com.dy.pipIrrIrrigate.irrigateGroup; import com.dy.common.aop.SsoAop; import com.dy.common.webUtil.BaseResponse; import com.dy.common.webUtil.BaseResponseUtils; import com.dy.common.webUtil.QueryResultVo; import com.dy.common.webUtil.ResultCodeMsg; import com.dy.pipIrrGlobal.pojoIr.IrGroupUnit; import com.dy.pipIrrGlobal.pojoIr.IrIrrigateGroup; import com.dy.pipIrrGlobal.pojoIr.IrIrrigateUnit; import com.dy.pipIrrGlobal.voIr.VoGroup; import com.dy.pipIrrGlobal.voIr.VoGroupOne; import com.dy.pipIrrGlobal.voIr.VoUnit; import com.dy.pipIrrGlobal.voIr.VoUnitOne; import com.dy.pipIrrGlobal.voSe.VoActiveCard; import com.dy.pipIrrIrrigate.irrigateUnit.IrrigateUnitSv; import com.dy.pipIrrIrrigate.irrigateGroup.QueryVo; import com.dy.pipIrrIrrigate.result.IrrigateResultCode; import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.media.Content; import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.responses.ApiResponse; import io.swagger.v3.oas.annotations.responses.ApiResponses; import io.swagger.v3.oas.annotations.tags.Tag; import jakarta.validation.Valid; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.MediaType; import org.springframework.transaction.annotation.Transactional; import org.springframework.validation.BindingResult; import org.springframework.web.bind.annotation.*; import java.util.List; import java.util.Map; import java.util.Objects; import java.util.Optional; /** * @author :WuZeYu * @Date :2024/5/21 16:19 * @LastEditTime :2024/5/21 16:19 * @Description */ @Slf4j @Tag(name = "轮灌组", description = "轮灌组") @RestController @RequestMapping(path = "group") @RequiredArgsConstructor public class IrrigateGroupCtrl { @Autowired private IrrigateGroupSv irrigateGroupSv; /** * 创建轮灌组 * * @param po 轮灌组实体对象 * @param bindingResult * @return 添加是否成功 */ @Operation(summary = "创建轮灌组记录", description = "创建轮灌组记录") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @PostMapping(path = "add", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse<Boolean> add(@RequestBody @Valid IrIrrigateGroup po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } try { Integer rec = Optional.ofNullable(irrigateGroupSv.addIrrigateGroup(po)).orElse(0); if (rec == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.ADD_PROJECT_FAIL.getMessage()); } } catch (Exception e) { log.error("创建轮灌组异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } /** * 逻辑删除灌溉单元 * @param * @return */ @Operation(summary = "逻辑删除轮灌组", description = "逻辑删除轮灌组") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @GetMapping(path = "delete") @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse<Boolean> delete( Long id) { if (id == null ) { BaseResponseUtils.buildFail(IrrigateResultCode.PLEASE_INPUT_PROJECT_ID.getMessage()); } // Long groupId = Long.parseLong(map.get("id").toString()); try { Integer rows = irrigateGroupSv.deleteIrrigateGroup(id); if (rows == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.DELETE_PROJECT_FAIL.getMessage()); } } catch (Exception e) { log.error("删除轮灌组异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } /** * 批量删除 * @param groupIds * @return */ @PostMapping(path = "delete_batch", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse<Boolean> delete_batch(@RequestBody Map<String, List> groupIds) { if (groupIds == null || groupIds.size() <= 0) { BaseResponseUtils.buildFail(IrrigateResultCode.PLEASE_INPUT_PROJECT_ID.getMessage()); } List ids = groupIds.get("groupIds"); for (int i = 0; i < ids.size(); i++) { long groupId = Long.parseLong(ids.get(i).toString()); try { Integer rows = irrigateGroupSv.deleteIrrigateGroup(groupId); if (rows == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.DELETE_PROJECT_FAIL.getMessage()); } } catch (Exception e) { log.error("删除轮灌组异常", e); return BaseResponseUtils.buildException(e.getMessage()); } } return BaseResponseUtils.buildSuccess(true); } /** * 修改灌溉单元 * @param po * @param bindingResult * @return */ @Operation(summary = "修改轮灌组", description = "修改轮灌组") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @PostMapping(path = "update", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse<Boolean> update(@RequestBody @Valid IrIrrigateGroup po, BindingResult bindingResult){ if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } try { Integer rec = Optional.ofNullable(irrigateGroupSv.updateIrrigateGroup(po)).orElse(0); if (rec == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.UPDATE_PROJECT_FAIL.getMessage()); } } catch (Exception e) { log.error("修改轮灌组异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } /** * 获取一个轮灌组 * * @return 获取一个轮灌组 */ @Operation(summary = "获取一个轮灌组", description = "获取一个轮灌组") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "获取一个轮灌组(BaseResponse.content:{})", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = IrIrrigateGroup.class))} ) }) @GetMapping(path = "one") @SsoAop() public BaseResponse<VoGroupOne> one(@RequestParam Long id) { VoGroupOne irIrrigateGroup = this.irrigateGroupSv.selectById(id); return BaseResponseUtils.buildSuccess(irIrrigateGroup); } /** * 分页查询 * @param vo * @return */ @Operation(summary = "获得一页轮灌组记录", description = "获得一页轮灌组记录") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "获得一页灌溉单元记录(BaseResponse.content:QueryResultVo[{}])", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = VoActiveCard.class))} ) }) @GetMapping(path = "some") @SsoAop() public BaseResponse<QueryResultVo<List<VoGroup>>> getIrrigateGroups(QueryVo vo) { try { QueryResultVo<List<VoGroup>> res = irrigateGroupSv.getIrrigateGroups(vo); return BaseResponseUtils.buildSuccess(res); } catch (Exception e) { log.error("获取轮灌组记录异常", e); return BaseResponseUtils.buildException(e.getMessage()); } } /** * 轮灌组添加灌溉单元 * * @param po 轮灌组灌溉单元中间表 * @param bindingResult * @return 添加是否成功 */ @Operation(summary = "轮灌组添加灌溉单元", description = "轮灌组添加灌溉单元") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @PostMapping(path = "add_unit", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse<Boolean> addGroupUnit(@RequestBody @Valid IrGroupUnit po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } try { Integer rec = Optional.ofNullable(irrigateGroupSv.addGroupUnit(po)).orElse(0); if (rec == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.ADD_PROJECT_FAIL.getMessage()); } } catch (Exception e) { log.error("轮灌组添加灌溉单元异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } /** * 逻辑删除 轮灌组移除灌溉单元 * @param * @return */ @Operation(summary = "轮灌组移除灌溉单元", description = "轮灌组移除灌溉单元") @ApiResponses(value = { @ApiResponse( responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, description = "操作结果:true:成功,false:失败(BaseResponse.content)", content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, schema = @Schema(implementation = Boolean.class))} ) }) @PostMapping(path = "remove_unit") @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse<Boolean> deleteGroupUnit(@RequestBody @Valid IrGroupUnit po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } try { Integer rec = Optional.ofNullable(irrigateGroupSv.deleteGroupUnit(po)).orElse(0); if (rec == 0) { return BaseResponseUtils.buildFail(IrrigateResultCode.DELETE_PROJECT_FAIL.getMessage()); } } catch (Exception e) { log.error("轮灌组移除灌溉单元异常", e); return BaseResponseUtils.buildException(e.getMessage()); } return BaseResponseUtils.buildSuccess(true); } } pipIrr-platform/pipIrr-web/pipIrr-web-irrigate/src/main/java/com/dy/pipIrrIrrigate/irrigateGroup/IrrigateGroupSv.java
New file @@ -0,0 +1,135 @@ package com.dy.pipIrrIrrigate.irrigateGroup; import com.dy.common.webUtil.QueryResultVo; import com.dy.pipIrrGlobal.daoIr.IrGroupUnitMapper; import com.dy.pipIrrGlobal.daoIr.IrIrrigateGroupMapper; import com.dy.pipIrrGlobal.pojoIr.IrGroupUnit; import com.dy.pipIrrGlobal.pojoIr.IrIrrigateGroup; import com.dy.pipIrrGlobal.voIr.VoGroup; import com.dy.pipIrrGlobal.voIr.VoGroupOne; import lombok.extern.slf4j.Slf4j; import org.apache.dubbo.common.utils.PojoUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.Date; import java.util.List; import java.util.Map; /** * @author :WuZeYu * @Date :2024/5/21 15:57 * @LastEditTime :2024/5/21 15:57 * @Description */ @Slf4j @Service public class IrrigateGroupSv { @Autowired private IrIrrigateGroupMapper irIrrigateGroupMapper; @Autowired private IrGroupUnitMapper irGroupUnitMapper; /** * 创建轮灌组 * * @param po * @return */ public Integer addIrrigateGroup(IrIrrigateGroup po) { po.setOperateDt(new Date()); po.setDeleted((byte) 0); int rows = irIrrigateGroupMapper.insertSelective(po); if (rows == 0) { return 0; } return 1; } /** * 删除轮灌组 * * @param id */ public Integer deleteIrrigateGroup(Long id) { int rows = irIrrigateGroupMapper.deleteLogicById(id); int rows1 = irGroupUnitMapper.deleteByGroupId(id); if (rows == 0) { return 0; } return 1; } /** * 修改轮灌组 * @param po * @return */ public Integer updateIrrigateGroup(IrIrrigateGroup po){ po.setOperateDt(new Date()); int rows = irIrrigateGroupMapper.updateByPrimaryKeySelective(po); if (rows == 0){ return 0; } return 1; } /** * 获取一个轮灌组 * @param id * @return */ public VoGroupOne selectById(Long id){ VoGroupOne unit = irIrrigateGroupMapper.selectById(id); return unit; } /** * 分页查询轮灌组 * @param queryVo * @return */ public QueryResultVo<List<VoGroup>> getIrrigateGroups(QueryVo queryVo){ Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo); Long itemTotal = irIrrigateGroupMapper.getRecordCount(params); QueryResultVo<List<VoGroup>> rsVo = new QueryResultVo<>(); rsVo.pageSize = queryVo.pageSize; rsVo.pageCurr = queryVo.pageCurr; rsVo.calculateAndSet(itemTotal, params); rsVo.obj = irIrrigateGroupMapper.getIrrigateGroups(params); return rsVo; } /** * 轮灌组添加灌溉单元 * * @param po * @return */ public Integer addGroupUnit(IrGroupUnit po) { po.setOperateDt(new Date()); po.setDeleted((byte) 0); int rows = irGroupUnitMapper.insertSelective(po); if (rows == 0) { return 0; } return 1; } /** * 轮灌组移除灌溉单元 * * @param po * @return */ public Integer deleteGroupUnit(IrGroupUnit po) { po.setOperateDt(new Date()); int rows = irGroupUnitMapper.deleteByUnitIdGroupId(po); if (rows == 0) { return 0; } return 1; } } pipIrr-platform/pipIrr-web/pipIrr-web-irrigate/src/main/java/com/dy/pipIrrIrrigate/irrigateGroup/QueryVo.java
New file @@ -0,0 +1,26 @@ package com.dy.pipIrrIrrigate.irrigateGroup; import com.dy.common.webUtil.QueryConditionVo; import io.swagger.v3.oas.annotations.media.Schema; import lombok.*; /** * @author :WuZeYu * @Date :2024/5/15 21:11 * @LastEditTime :2024/5/15 21:11 * @Description */ @Data @EqualsAndHashCode(callSuper = false) @ToString(callSuper = true) @NoArgsConstructor @AllArgsConstructor @Builder @Schema(name = "项目查询条件") public class QueryVo extends QueryConditionVo { @Schema(description = "项目名称") public String projectName; @Schema(description = "轮罐组名称") public String groupCode; }