| pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoIr/IrCropMapper.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
| pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoIr/IrCrop.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
| pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voIr/VoCrop.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
| pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrCropMapper.xml | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
| pipIrr-platform/pipIrr-web/pipIrr-web-irrigate/src/main/java/com/dy/pipIrrIrrigate/crop/CropCtrl.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
| pipIrr-platform/pipIrr-web/pipIrr-web-irrigate/src/main/java/com/dy/pipIrrIrrigate/crop/CropSv.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
| pipIrr-platform/pipIrr-web/pipIrr-web-irrigate/src/main/java/com/dy/pipIrrIrrigate/crop/QueryVo.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 |
pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoIr/IrCropMapper.java
New file @@ -0,0 +1,44 @@ package com.dy.pipIrrGlobal.daoIr; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.dy.pipIrrGlobal.pojoIr.IrCrop; import com.dy.pipIrrGlobal.pojoIr.IrProject; import com.dy.pipIrrGlobal.voIr.VoCrop; import com.dy.pipIrrGlobal.voIr.VoProject; import org.apache.ibatis.annotations.Mapper; import java.util.List; import java.util.Map; /** * @author :WuZeYu * @Date :2024/5/24 13:55 * @LastEditTime :2024/5/24 13:55 * @Description */ @Mapper public interface IrCropMapper extends BaseMapper<IrCrop> { //增 int insertSelective(IrCrop record); //删 int deleteLogicById(Long id); //改 int updateByPrimaryKeySelective(IrCrop record); /** * 根据指定条件获取项目记录数 * * @param params * @return */ Long getRecordCount(Map<?, ?> params); /** * 根据指定条件获取项目记录 * * @param params * @return */ List<VoCrop> getCrops(Map<?, ?> params); } pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoIr/IrCrop.java
New file @@ -0,0 +1,57 @@ 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 lombok.*; import org.apache.logging.log4j.core.config.plugins.validation.constraints.NotBlank; /** * @author :WuZeYu * @Date :2024/5/24 9:43 * @LastEditTime :2024/5/24 9:43 * @Description */ /** * 作物表 */ @TableName(value="ir_crop", autoResultMap = true) @Data @ToString @Builder @NoArgsConstructor @AllArgsConstructor @Schema(name = "作物实体") public class IrCrop implements BaseEntity { /** * 主键 */ @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 cropName; /** * 备注 */ @Schema(description = "备注", requiredMode = Schema.RequiredMode.REQUIRED) private String remarks; /** * 逻辑删除标识;0-未删除,1-删除 */ @Schema(description = "删除标识", requiredMode = Schema.RequiredMode.NOT_REQUIRED) private Byte deleted; } pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voIr/VoCrop.java
New file @@ -0,0 +1,22 @@ package com.dy.pipIrrGlobal.voIr; import com.dy.common.po.BaseEntity; import io.swagger.v3.oas.annotations.media.Schema; import lombok.Data; import org.apache.logging.log4j.core.config.plugins.validation.constraints.NotBlank; /** * @author :WuZeYu * @Date :2024/5/25 9:29 * @LastEditTime :2024/5/25 9:29 * @Description */ @Data @Schema(name = "作物视图") public class VoCrop implements BaseEntity { @Schema(description = "实体id") private Long id; @Schema(description = "作物名称") private String cropName; } pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrCropMapper.xml
New file @@ -0,0 +1,99 @@ <?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.IrCropMapper"> <resultMap id="BaseResultMap" type="com.dy.pipIrrGlobal.pojoIr.IrCrop"> <!--@mbg.generated--> <!--@Table ir_crop--> <id column="id" jdbcType="BIGINT" property="id" /> <result column="crop_name" jdbcType="VARCHAR" property="cropName" /> <result column="remarks" jdbcType="VARCHAR" property="remarks" /> <result column="deleted" jdbcType="TINYINT" property="deleted" /> </resultMap> <sql id="Base_Column_List"> <!--@mbg.generated--> id, crop_name, remarks, deleted </sql> <!--添加--> <insert id="insertSelective" parameterType="com.dy.pipIrrGlobal.pojoIr.IrCrop"> insert into ir_crop <trim prefix="(" suffix=")" suffixOverrides=","> <if test="id != null"> id, </if> <if test="cropName != null"> crop_name, </if> <if test="remarks != null"> remarks, </if> <if test="deleted != null"> deleted, </if> </trim> <trim prefix="values (" suffix=")" suffixOverrides=","> <if test="id != null"> #{id,jdbcType=BIGINT}, </if> <if test="cropName != null"> #{cropName,jdbcType=VARCHAR}, </if> <if test="remarks != null"> #{remarks,jdbcType=VARCHAR}, </if> <if test="deleted != null"> #{deleted,jdbcType=TINYINT}, </if> </trim> </insert> <!--逻辑删除--> <delete id="deleteLogicById" parameterType="java.lang.Long"> <!--@mbg.generated--> update ir_crop set deleted = 1 where id = #{id,jdbcType=BIGINT} </delete> <!--修改信息--> <update id="updateByPrimaryKeySelective" parameterType="com.dy.pipIrrGlobal.pojoIr.IrCrop"> update ir_crop <set> <if test="cropName != null"> crop_name = #{cropName,jdbcType=VARCHAR}, </if> <if test="remarks != null"> remarks = #{remarks,jdbcType=VARCHAR}, </if> <if test="deleted != null"> deleted = #{deleted,jdbcType=TINYINT}, </if> </set> where id = #{id,jdbcType=BIGINT} </update> <select id="getRecordCount" resultType="java.lang.Long"> SELECT COUNT(*) AS recordCount FROM ir_crop cro <where> cro.deleted = 0 <if test="cropName != null and cropName != ''"> AND cro.crop_name LIKE CONCAT('%', #{cropName}, '%') </if> </where> </select> <select id="getCrops" resultType="com.dy.pipIrrGlobal.voIr.VoCrop"> SELECT CAST(cro.id AS char)AS id, cro.crop_name AS cropName FROM ir_crop cro <where> cro.deleted = 0 <if test="cropName != null and cropName != ''"> AND cro.crop_name LIKE CONCAT('%', #{cropName}, '%') </if> </where> <if test="pageCurr != null and pageSize != null"> LIMIT ${(pageCurr-1)*pageSize}, ${pageSize} </if> </select> </mapper> pipIrr-platform/pipIrr-web/pipIrr-web-irrigate/src/main/java/com/dy/pipIrrIrrigate/crop/CropCtrl.java
New file @@ -0,0 +1,177 @@ package com.dy.pipIrrIrrigate.crop; 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.IrCrop; import com.dy.pipIrrGlobal.pojoIr.IrProject; import com.dy.pipIrrGlobal.voIr.VoCrop; import com.dy.pipIrrGlobal.voIr.VoProject; import com.dy.pipIrrGlobal.voSe.VoActiveCard; import com.dy.pipIrrIrrigate.crop.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.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/24 19:38 * @LastEditTime :2024/5/24 19:38 * @Description */ @Slf4j @Tag(name = "作物管理", description = "作物操作") @RestController @RequestMapping(path = "crop") @RequiredArgsConstructor public class CropCtrl { private final CropSv cropSv; /** * 添加作物 * * @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 IrCrop po, BindingResult bindingResult) { if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } try { Integer rec = Optional.ofNullable(cropSv.addCrop(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 map * @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 = "delete", consumes = MediaType.APPLICATION_JSON_VALUE) @Transactional(rollbackFor = Exception.class) @SsoAop() public BaseResponse<Boolean> delete(@RequestBody Map map) { if (map == null || map.size() <= 0) { BaseResponseUtils.buildFail(IrrigateResultCode.PLEASE_INPUT_PROJECT_ID.getMessage()); } Long cropId = Long.parseLong(map.get("id").toString()); try { Integer rows = cropSv.deleteCrop(cropId); 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 IrCrop po, BindingResult bindingResult){ if (bindingResult != null && bindingResult.hasErrors()) { return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } try { Integer rec = Optional.ofNullable(cropSv.updateCrop(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); } /** * 分页查询 * @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<VoCrop>>> getCrops(QueryVo vo) { try { QueryResultVo<List<VoCrop>> res = cropSv.getCrops(vo); return BaseResponseUtils.buildSuccess(res); } catch (Exception e) { log.error("获取作物记录异常", e); return BaseResponseUtils.buildException(e.getMessage()); } } } pipIrr-platform/pipIrr-web/pipIrr-web-irrigate/src/main/java/com/dy/pipIrrIrrigate/crop/CropSv.java
New file @@ -0,0 +1,87 @@ package com.dy.pipIrrIrrigate.crop; import com.dy.common.webUtil.QueryResultVo; import com.dy.pipIrrGlobal.daoIr.IrCropMapper; import com.dy.pipIrrGlobal.pojoIr.IrCrop; import com.dy.pipIrrGlobal.voIr.VoCrop; import com.dy.pipIrrIrrigate.crop.QueryVo; 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/24 19:38 * @LastEditTime :2024/5/24 19:38 * @Description */ @Slf4j @Service public class CropSv { @Autowired private IrCropMapper irCropMapper; /** * 添加项目 * * @param po * @return */ public Integer addCrop(IrCrop po) { po.setDeleted((byte) 0); int rows = irCropMapper.insertSelective(po); if (rows == 0) { return 0; } return 1; } /** * 删除项目 * * @param id */ public Integer deleteCrop(Long id) { int rows = irCropMapper.deleteLogicById(id); if (rows == 0) { return 0; } return 1; } /** * 修改项目信息 * @param po * @return */ public Integer updateCrop(IrCrop po){ int rows = irCropMapper.updateByPrimaryKeySelective(po); if (rows == 0){ return 0; } return 1; } /** * 分页查询项目 * @param queryVo * @return */ public QueryResultVo<List<VoCrop>> getCrops(QueryVo queryVo){ Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo); Long itemTotal = irCropMapper.getRecordCount(params); QueryResultVo<List<VoCrop>> rsVo = new QueryResultVo<>(); rsVo.pageSize = queryVo.pageSize; rsVo.pageCurr = queryVo.pageCurr; rsVo.calculateAndSet(itemTotal, params); rsVo.obj = irCropMapper.getCrops(params); return rsVo; } } pipIrr-platform/pipIrr-web/pipIrr-web-irrigate/src/main/java/com/dy/pipIrrIrrigate/crop/QueryVo.java
New file @@ -0,0 +1,23 @@ package com.dy.pipIrrIrrigate.crop; import com.dy.common.webUtil.QueryConditionVo; import io.swagger.v3.oas.annotations.media.Schema; import lombok.*; /** * @author :WuZeYu * @Date :2024/5/24 19:53 * @LastEditTime :2024/5/24 19:53 * @Description */ @Data @EqualsAndHashCode(callSuper = false) @ToString(callSuper = true) @NoArgsConstructor @AllArgsConstructor @Builder @Schema(name = "作物查询条件") public class QueryVo extends QueryConditionVo { @Schema(description = "作物名称") public String cropName; }