今天遇到这么一个问题,要求拖拽树上的节点,更换父级机构并完成在新机构下排序功能,按下图来说,将“客户类型-城镇居民下的政府公职人员”拖拽到“使用状态”下,完成操作之后前台会给传一个当前机构的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,2,2)进行排序,然后在按照如果机构ID等于当前要处理的机构的ID,说明他是要往前排的,所以使用了DECODE(C.ORGID, ?, C.ORGID),也就是说如果查询的数据,机构ID等于当前机构ID,那就有值,如果不是,那就没值,这样排序下来就是排序顺序中出现相同排序序号的时候,当前处理机构更靠前(这个地方说一点,编写SQL的时候,是不建议在排序中使用运算的,有大牛帮忙给出个好的处理方式没)
- 获取对应的ROWNUM,根据内外ORGID相等的条件进行新顺序的更新