实现目录数据的上移(up)、下移(down)、置顶(top)、置底(bottom)的操作

java 复制代码
@ApiOperation("8-15 交接班-标签设置排序")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "id", value = "id", dataType = "string", required = true),
            @ApiImplicitParam(name = "orgnCode", value = "机构代码", dataType = "string", required = true),
            @ApiImplicitParam(name = "sortId", value = "排序id", dataType = "string", required = true),
            @ApiImplicitParam(name = "sectionCode", value = "科室代码", dataType = "string", required = true),
            @ApiImplicitParam(name = "button", value = "上移(up)、下移(down)、置顶(top)、置底(bottom)", dataType = "string", required = true),
    })
    @GetMapping("sortOperate")
    public ResponseEntity<Object> sortOperate(@RequestParam("id") String id,
                                              @RequestParam("orgnCode") String orgnCode,
                                              @RequestParam("sortId") String sortId,
                                              @RequestParam("sectionCode") String sectionCode,
                                              @RequestParam("button") String button) {
        return shiftService.sortOperate(id, orgnCode, sortId, sectionCode, button);
    }
java 复制代码
ResponseEntity<Object> sortOperate(String id, String orgnCode, String sortId, String sectionCode, String button);
java 复制代码
@Override
    public ResponseEntity<Object> sortOperate(String id, String orgnCode, String sortId, String sectionCode, String button) {
        ResponseMessage<Object> responseMessage = new ResponseMessage();
        //上移(up)、下移(down)、置顶(top)、置底(bottom)
        if (button != null && button.equals("up")) {
        	//查出小于排序id的第一个
            HashMap<String, String> sortMap = nursingHandoverMapper.infoBySortUp(orgnCode, sectionCode, sortId);
            if (sortMap != null && !sortMap.isEmpty()) {
                String upId = sortMap.get("id");
                String upSortId = sortMap.get("sortId");
                if (StringUtil.isNotEmpty(upId) && StringUtil.isNotEmpty(upSortId)) {
                    nursingHandoverMapper.updateBySort(upId, sortId);
                    nursingHandoverMapper.updateBySort(id, upSortId);
                }
            }
        } else if (button != null && button.equals("down")) {
            HashMap<String, String> sortMap = nursingHandoverMapper.infoBySortDown(orgnCode, sectionCode, sortId);
            if (sortMap != null && !sortMap.isEmpty()) {
                String downId = sortMap.get("id");
                String downSortId = sortMap.get("sortId");
                if (StringUtil.isNotEmpty(downId) && StringUtil.isNotEmpty(downSortId)) {
                    nursingHandoverMapper.updateBySort(downId, sortId);
                    nursingHandoverMapper.updateBySort(id, downSortId);
                }
            }
        } else if (button != null && button.equals("top")) {
            HashMap<String, String> sortMap = nursingHandoverMapper.infoBySortTop(orgnCode, sectionCode);
            if (sortMap != null && !sortMap.isEmpty()) {
                String topId = sortMap.get("id");
                String topSortId = sortMap.get("sortId");
                if (StringUtil.isNotEmpty(topId) && StringUtil.isNotEmpty(topSortId)) {
                    nursingHandoverMapper.updateBySort(topId, sortId);
                    nursingHandoverMapper.updateBySort(id, topSortId);
                }
            }
        } else if (button != null && button.equals("bottom")) {
            HashMap<String, String> sortMap = nursingHandoverMapper.infoBySortTop(orgnCode, sectionCode);
            if (sortMap != null && !sortMap.isEmpty()) {
                String bottomId = sortMap.get("id");
                String bottomSortId = sortMap.get("sortId");
                if (StringUtil.isNotEmpty(bottomId) && StringUtil.isNotEmpty(bottomSortId)) {
                    nursingHandoverMapper.updateBySort(bottomId, sortId);
                    nursingHandoverMapper.updateBySort(id, bottomSortId);
                }
            }
        }
        responseMessage.setCode("T").setMessage("success");
        return new ResponseEntity<>(responseMessage, HttpStatus.OK);
    }
java 复制代码
HashMap<String, String> infoBySortUp(@Param("orgnCode") String orgnCode, @Param("sectionCode") String sectionCode, @Param("sortId") String sortId);

<select id="infoBySortUp" resultType="java.util.HashMap">
        SELECT top 1 ID id, SORT_ID sortId
        from NEMR_SET_SHIFT
        WHERE ORGN_CODE = #{orgnCode}
          AND SECTION_CODE = #{sectionCode}
          AND SORT_ID &lt; #{sortId}
        ORDER BY SORT_ID DESC
    </select>
java 复制代码
HashMap<String, String> infoBySortDown(@Param("orgnCode") String orgnCode, @Param("sectionCode") String sectionCode, @Param("sortId") String sortId);

<select id="infoBySortDown" resultType="java.util.HashMap">
        SELECT top 1 ID id, SORT_ID sortId
        from NEMR_SET_SHIFT
        WHERE ORGN_CODE = #{orgnCode}
          AND SECTION_CODE = #{sectionCode}
          AND SORT_ID &gt; #{sortId}
        ORDER BY SORT_ID asc
    </select>
java 复制代码
HashMap<String, String> infoBySortTop(@Param("orgnCode") String orgnCode, @Param("sectionCode") String sectionCode);

<select id="infoBySortTop" resultType="java.util.HashMap">
        SELECT top 1 ID id, SORT_ID sortId
        FROM NEMR_SET_SHIFT(nolock)
        WHERE ORGN_CODE = #{orgnCode}
          AND SECTION_CODE = #{sectionCode}
        order by SORT_ID asc
    </select>
java 复制代码
HashMap<String, String> infoBySortTop(@Param("orgnCode") String orgnCode, @Param("sectionCode") String sectionCode);


<select id="infoBySortTop" resultType="java.util.HashMap">
        SELECT top 1 ID id, SORT_ID sortId
        FROM NEMR_SET_SHIFT(nolock)
        WHERE ORGN_CODE = #{orgnCode}
          AND SECTION_CODE = #{sectionCode}
        order by SORT_ID asc
    </select>
相关推荐
BillKu27 分钟前
Java解析前端传来的Unix时间戳
java·前端·unix
幼稚诠释青春28 分钟前
面试实例题
java·开发语言
cui_hao_nan39 分钟前
多轮对话实现
java·语言模型
饼干ovo40 分钟前
shell编程
java·git·github
华科云商xiao徐1 小时前
Java使用Jsoup库实现通用爬虫
java·爬虫
闲敲棋子落灯华1 小时前
java学习笔记(三)--java包的引入、访问控制、类的继承、super关键字、重载、重写、运算符、拆箱
java·后端
程序员岳焱1 小时前
Java 使用 Spring AI 的 10 个实用技巧
java·后端·程序员
Bug改不动了1 小时前
迁移达梦数据库过程中,如何快速识别需要改写的Mapper SQL方法
java·mybatis
crud1 小时前
Spring Boot 使用 @Async 实现异步操作:从入门到实战,一文讲透
java·spring boot