//sima 传入uid 得到所有上级部门负责人id
private function partment($uid,$level='')
{
//传入部门id 返回本部门所有上级部门负责人的id
$data = array();
function sima($pid)
{
$res = M('Department')
->alias('d')
->field('d.did did ,p.did pid , d.dperson dp , p.dperson pd')
->join('ganen_department p on d.dpid = p.did ')
->where("d.did = $pid")
->find();
$data =$res['pd'];
if(!empty($res['pid']) )
{
$data=$data.','.sima($res['pid']);
}
//如果得到的是0或者null 则跳过
return trim(trim($data,','),'0');
}
//传入uid 得到部门id
$res = M('Department_station')->field('did')->where("uid = $uid")->find();
if(!empty($res['did']))
{
$did = $res['did'];
}else{
return '部门有误';
}
$leader_id = sima($did);
//判断传入的uid 是否为本部门的负责人
//如果为本部门的负责人 则不必区分是否为 项目
$Depar = M('Department')->field('dperson,is_pro')->where("did = $did")->find();
if($uid != $Depar['dperson'])
{
//将本部门负责人的id 加上
$leader_id = $Depar['dperson'].','.$leader_id;
//查找项目负责人的id 要区分是咨询部还是项目部
//查到所负责项目的主管 如果只有一个项目 主管审批 如果多个项目 主管不批 总监审批
$res = M('Project_salary')->field('projectids')->where("uid = $uid and status = 1")->find();
$pro = $res['projectids'];
//判断是否只有一个项目
$arr = explode(',',$pro);
//删除数组内的空值
$arr = array_filter($arr);
$charge = '';
if(count($arr) == 1)
{
//项目部
if($Depar['is_pro'] == 1)
{
$res=M('Project')->field('charge')->where("id = $pro")->find();
$charge['leader'] = $res['charge'];
}
//咨询部
if($Depar['is_pro'] == 2)
{
$res=M('Project')->field('charge_answer')->where("id = $pro")->find();
$charge['leader'] = $res['charge_answer'];
}
}

}
//判断是否为项目部门
//解决负责人为0 出现,的问题
//将字符串变为数组
$arr = explode(',',$leader_id);
//删除数组内的空值
$arr_id = array_filter($arr);

//判断主管id是否为空
if(!empty($charge['leader']))
{
//在数组的头部植入主管id
array_unshift($arr_id,$charge['leader']);
//$leader_id = $charge['leader'].','.$leader_id;
}
//判断审批级别
if(!empty($level))
{
//通过审批级别 得到截取数组
$arr_id =array_slice($arr_id,0,$level);
}
//将数组重新变为字符串
$leader_id = implode(',',$arr_id);
return $leader_id;
}

获得审批人的id的更多相关文章

  1. 关于OA流程相关数据表的设计

    一.前言 近期有些同学问起流程的表设计,终于有时间能写下博客,并整理下之前所发布的文章. 之前的文章讲到的表设计,没有给全且还存在漏洞,在这里向各位同学表示歉意.这是我个人最新领悟的一些流程思维,欢迎 ...

  2. flowable的多人会签和一票否决

    项目结构: 接下来代码: Duorenhuiqian.bpmn20.xml: <?xml version="1.0" encoding="UTF-8"?& ...

  3. 关于全局ID,雪花(snowflake)算法的说明

    上次简单的说一下:http://www.cnblogs.com/dunitian/p/6041745.html#uid C#版本的国外朋友已经封装了,大家可以去看看:https://github.co ...

  4. 有朋友问了数据库ID不连续,怎么获取上一篇和下一篇的文章?(不是所有情况都适用)

    呃 (⊙o⊙)…,逆天好久没写SQL了,EF用的时间长了,SQL都不怎么熟悉了......[SQL水平比较菜,大牛勿喷] 方法很多种,说个最常见的处理 因为id是自增长的,所以一般情况下下一篇文章的I ...

  5. android 使用Tabhost 发生could not create tab content because could not find view with id 错误

    使用Tabhost的时候经常报:could not create tab content because could not find view with id 错误. 总结一下发生错误的原因,一般的 ...

  6. SharePoint 2013: A feature with ID has already been installed in this farm

    使用Visual Studio 2013创建一个可视web 部件,当右击项目选择"部署"时报错: "Error occurred in deployment step ' ...

  7. ILJMALL project过程中遇到Fragment嵌套问题:IllegalArgumentException: Binary XML file line #23: Duplicate id

    出现场景:当点击"分类"再返回"首页"时,发生error退出   BUG描述:Caused by: java.lang.IllegalArgumentExcep ...

  8. thinkphp-无限分类下根据任意部门获取顶级部门ID

    根据所得到的部门编号获取顶级部门ID: 参数 - department_id 表格组织架构: tab_departments department_id parent_id name 1 1 顶级 2 ...

  9. 分布式唯一ID生成服务

    SNService是一款基于分布式的唯一ID生成服务,主要用于提供大数量业务数据建立唯一ID的需要;服务提供最低10K/s的唯一ID请求处理.如果你部署服务的CPU资源达到4核的情况下那该服务最低可以 ...

随机推荐

  1. Python程序的执行过程

    1. Python是一门解释型语言? 我初学Python时,听到的关于Python的第一句话就是,Python是一门解释性语言,我就这样一直相信下去,直到发现了*.pyc文件的存在.如果是解释型语言, ...

  2. php5.3中namespace的说明,帮助初次接触namespace的phper快速理解

    命名空间一个最明确的目的就是解决重名问题,PHP中不允许两个函数或者类出现相同的名字,否则会产生一个致命的错误.这种情况下只要避免命名重复就可以解决,最常见的一种做法是约定一个前缀,但是方法名变的很长 ...

  3. git学习记录——远程仓库(说白了就是代码放到githup上)

    远程仓库 现在讲述的这些SVN都已经做到了,并没什么稀奇的地方 所以这节课赘述的是杀手级的东西——远程仓库githup ssh-keygen -t rsa  -C "xxxxxxxxxxx@ ...

  4. 20190927 - 28 后觉 「雅礼Day3 - 4」

    我再不开$C++11$编译我就从三楼跳下去$$\text{%%%lsc}$$ Day3 -lm -O2 -std=c++ Before $Day3$? 全是$Subtask$? $\frac{1}{4 ...

  5. Connection reset问题,INFO: I/O exception (java.net.SocketException) caught when processing reques

    困扰我多年的Connection reset问题 第一次出现:是thrift的python client去请求server,发现偶尔出现这个问题 第二次:接入第三方的api,去请求数据时,发现一个接入 ...

  6. Linux安装Desktop 和 vncserver

    sudo su - #使用 root 账户 yum grouplist #查看所有可用的group yum groupinstall GNOME Desktop #安装 GNOME 桌面 yum -y ...

  7. applyMiddleware源码中的闭包

    闭包都是个老掉牙的话题了,这次又提起,是因为重看Redux源码时发现了applyMiddleware里的用法很巧妙.我们先看一个简单的例子. var a = (num) => num + 1 v ...

  8. linux环境变量设置命令

    1echo $ <变量名> //显示某个环境变量 2env     // environment (环境) 的简写,列出来所有的环境变量 3set     //显示所有本地定义的Shell ...

  9. JavaScript 中的多线程通信的方法

    在Html 5诞生之后,我们可以使用javascript来实现多线程处理.H5 新增了一个web workers api,使用这个API,用户可以很容易地创建在后台运行的线程,H5 中被称为workd ...

  10. 将CMD命令提示符的起始位置进行更改 / CMD起始位置发生改变后如何修改回来

    具体步骤如下: 1.首先我们需要先找到命令提示符所在的文件目录.可以在开始运行程序中输入CMD,一般回自动搜索匹配. 2.右键点击命令提示符,在弹出菜单中,选择“打开文件位置”: 3.然后我们就可以进 ...