Oracle树形结构拖拽之插队重新排序

今天遇到这么一个问题,要求拖拽树上的节点,更换父级机构并完成在新机构下排序功能,按下图来说,将“客户类型-城镇居民下的政府公职人员”拖拽到“使用状态”下,完成操作之后前台会给传一个当前机构的ID,新父级机构的ID,拖放完成后所在的位置,假设使用状态下“启用”和“停用”原来的排序是1和2,放的时候放在了“启用”后面,也就是新的被拖拽的“政府公职人员”的新排序是2,这个和停用的排序数是一样,这个时候进行排序的时候,就会出现他俩不确定哪个靠前的问题,然后就有了最下面的SQL,新手,有优化之处,请大牛指导

        sql.append(" UPDATE SYS_ORG A ");
        sql.append(" SET A.LEVELSORT =  ");
        sql.append("        (SELECT RN ");
        sql.append(" FROM (SELECT ROWNUM RN, ORGID, UPORGID, LEVELSORT ");
        sql.append("         FROM (SELECT ORGID, UPORGID, C.ORGNAME, LEVELSORT ");
        sql.append("                 FROM SYS_ORG C ");
        sql.append("                WHERE UPORGID = ? ");
        sql.append("                ORDER BY C.LEVELSORT, ");
        //这个地方是绕弯的方法,如果ID等于当前机构ID的时候,则进行进行排序,这样就保证了当前机构会排在与其Levelsort一样的机构前面
        sql.append("                 DECODE(C.ORGID, ?, C.ORGID))) B ");
        sql.append(" WHERE A.ORGID = B.ORGID) ");
        sql.append(" WHERE A.UPORGID = ? ");

SQL解析(从内往外分析):

  1. 首先按照目前的顺序(1,2,2)进行排序,然后在按照如果机构ID等于当前要处理的机构的ID,说明他是要往前排的,所以使用了DECODE(C.ORGID, ?, C.ORGID),也就是说如果查询的数据,机构ID等于当前机构ID,那就有值,如果不是,那就没值,这样排序下来就是排序顺序中出现相同排序序号的时候,当前处理机构更靠前(这个地方说一点,编写SQL的时候,是不建议在排序中使用运算的,有大牛帮忙给出个好的处理方式没
  2. 获取对应的ROWNUM,根据内外ORGID相等的条件进行新顺序的更新
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值