递归方法,查询出树该组织及以下组织的组织ID
-- 查询出该组织下所有组织id的集合
--方法一:
public String getAllOrgidsTwo(Integer orgid){
List<Integer> orgids=new ArrayList<Integer>();
orgids.add(orgid);
List<Integer> result=new ArrayList<Integer>();
String result1=getAllOrgidTwo(orgids, result).toString();
result1=result1.replace("[", "");
result1=result1.replace("]", "");
String result2=getAllOrgids(orgid);
return result2;
}
/**
* 查询出该组织及以下组织的所有组织ID方法二
* @param orgid
* @param list
* @return
*/
public List<Integer> getAllOrgidTwo(List<Integer> orgid,List<Integer> list){
list.addAll(orgid);
List<Integer> intList=new ArrayList<Integer>();
for(Integer i : orgid){
List<Org> orglist = orgService.selectInfo(" FROM Org Where parentId="+i);
for(Org o : orglist){
intList.add(o.getOrgid());
}
}
if(intList.size()>0){
return getAllOrgidTwo(intList,list);
}
return list;
}
--方法二:
/**
* 传组织ID查询出该组织及以下组织的所有组织ID 2017-11-23 HJJ
*/
public String getAllOrgids(Integer orgid){
String allOrgId=getAllOrgid(orgid,"");
if("".equals(allOrgId)){
return orgid.toString();
}else{
allOrgId+=","+orgid;
return allOrgId;
}
}
/**
* 传组织ID和接收String,查询出该组织以下组织(不包括本组织)的所有组织ID 2017-11-23 HJJ
*/
public String getAllOrgid(Integer orgid,String str){
List<Org> orglist = orgService.selectInfo("FROM Org ");
if(orglist!=null&&orglist.size()>0){
int index = 0;
for(Org o : orglist){
String parentId1=o.getParentId().toString();
String orgidNow1=orgid.toString();
if(parentId1.equals(orgidNow1)){
if(index > 0){
str += ",";
index = 0;
}
str+=o.getOrgid();
boolean bool = false;
for(int j=0; j< orglist.size(); j++){
String parentId2=orglist.get(j).getParentId().toString();
String orgidNow2=o.getOrgid().toString();
if(parentId2.equals(orgidNow2)){
bool = true;
break;
}
}
if(bool){
// 调用自身,实现递归
str += ",";
str = getAllOrgid(o.getOrgid(),str);
}
index ++;
}
}
}
return str;
}
递归方法,查询出树该组织及以下组织的组织ID的更多相关文章
- [ 订单查询 ] 性能 高并发 : 分表 与 用户id%1024 存放表
逻辑剥离, 保留核心部分 下单 { 核心功能 -- 买家查看订单, 卖家查看收到订单, 修改价格 5个表 附属功能 -- 库存量, 发短信, 给卖家发通知, 订单统计, 销售额统计 } 下单时 一个数 ...
- laravel 列表搜索查询(when,with用法以及关联图像id处理图像路径)
laravel中比较常规的列表查询: /** * 活动列表 * @param Request $request * @return \Illuminate\Http\JsonResponse */ p ...
- Oracle采购模块中的多组织访问控制(MOAC)
1. 概述 从Release12开始启用多组织访问控制功能,将允许用户在一个单独的职责中访问一个或者多个经营单位(OU-Operation Units)的数据.这个功能允许用户在一个可共享服务的 ...
- Winform开发中对界面的组织布局
在设计界面的时候,不管是在Web端,还是在Winform端,或者是WPF或者移动界面等应用上,我们对界面的组织布局,一直是比较有趣的话题,而组织界面的好坏从用户的感受来看,可以提供程序可使用性高低,也 ...
- sql server 索引阐述系列三 表的堆组织
一. 概述 这一节来详细介绍堆组织,通过讲解堆的结构,堆与非聚集索引的关系,堆的应用场景,堆与聚集索引的存储空间占用,堆的页拆分现象,最后堆的使用建议 ,这几个维度来描述堆组织.在sqlserve ...
- CRM的组织架构
PPOMA_CRM... 和ERP的组织架构一样的. 这边在功能参数里匹配ECC的组织.ECC的组织架构则会设置控制范围,成本中心啊,业务范围,公司,人事范围等. 下面说说常见函数RH_STRUC_G ...
- Hyperledger Fabric 动态增加组织到网络中
本文基于Hyperledger Fabric 1.4版本. 官方文档地址:传送门 动态添加一个组织到Fabric网络中也是一个比较重要的功能.官方文档写的已经很详细了,有能力的尽量还是看官方文档,本文 ...
- 通过Ldap实现人事系统组织人事和AD的同步
项目需求:同步人事系统的组织架构-对应AD的OU树同步人事系统的员工-对应AD的用户 创建OU 名字不能重复,需要父级路径(parentOrganizeUnit)以及新ou的名字(name),如果最父 ...
- Fabric进阶(三)—— 使用SDK动态增加组织
在fabric网络运行过程中动态追加新的组织是相当复杂的,网上的资料也十分匮乏,大多是基于first-network这样的简单示例,而且是使用启动cli容器的方法来增加组织,几乎没有针对实际应用的解决 ...
随机推荐
- yii2 源码分析Action类分析 (六)
Action类是控制器的基类, <?php namespace yii\base; use Yii; /** * Action是所有控制器动作类的基类,它继承组件类 * * 动作提供了重用动作方 ...
- Install Centrifugo and quick start
Install Centrifugo and quick start Go is a perfect language - it gives developers an opportunity to ...
- centos ELK安装
本文来自我的github pages博客http://galengao.github.io/ 即www.gaohuirong.cn ELK是进行日志收集分析用的,具体工作.原理.作用自行google. ...
- sql server在一个字段相同值时,另一个字段结果拼接
如下字段红框里的信息都一样的,通过转换实现字段拼接 SELECT formmain_id,(SELECT field0040+';' FROM formson_5489 WHERE formmain_ ...
- PAT1116. Come on! Let's C (map)
思路:模拟一下就好了,map用来记录每个人的排名. AC代码 #include <stdio.h> #include <map> #include <math.h> ...
- SIFT解析(三)生成特征描述子
以上两篇文章中检测在DOG空间中稳定的特征点,lowe已经提到这些特征点是比Harris角点等特征还要稳定的特征.下一步骤我们要考虑的就是如何去很好地描述这些DOG特征点. 下面好好说说如何来描述这些 ...
- C语言老司机学Python (四)
字符串格式化: 可以使用类似c语言中sprintf函数的方法进行格式化,但是函数名称是print() 如:print('常量 PI 的值近似为:%5.3f.' % var_PI) 注意var_PI ...
- 移动端-手机端-日历选择控件(支持Zepto和JQuery)
一. 效果图 二. 功能说明 1. 支持切换年份,月份. 2. 支持点击选中日期,也可以点击确定选择日期. 三. 使用方法 1. 添加Input 在你的页面中添加Input输入框.可以再html里,也 ...
- Android shape使用详解
在android开发过程中,shape是比较常用的,用于设定控件的形状,可以在selector,layout等里面使用,有6个子标签,各属性说明如下: <?xml version="1 ...
- 如何在WDM中使用xp系统的DMA用来处理数据
最近做了一款pci的视频采集卡(H264压缩),由于数据传输量比较大,所有想采用dma来传输数据,刚开始感觉很简单,后来感觉还是困难重重. DMA 验证监控直接内存访问 (DMA) 的使用.随着 Wi ...