实现目录数据的上移(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>
相关推荐
MacroZheng1 小时前
Claude Code官方桌面端正式发布,夯爆了!
java·人工智能·后端
虚无境1 小时前
如何编写一个SpringBoot项目告警推送的Starter
java·prometheus·webhook
NE_STOP16 小时前
Vide Coding--AI编程工具的选择
java
码云数智-园园17 小时前
C++20 Modules 模块详解
java·开发语言·spring
程序员黑豆17 小时前
JDK 下载安装与配置详细教程
java·前端·ai编程
小宇宙Zz17 小时前
Maven依赖冲突
java·服务器·maven
swordbob17 小时前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
咖啡八杯18 小时前
GoF设计模式——享元模式
java·spring·设计模式·享元模式
十五喵源码网18 小时前
基于springboot2+vue2的租房管理系统
java·毕业设计·springboot·论文笔记