//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. Shell脚本编程中截取字符串方法

    例如: 假设变量var=http://www.baidu.com/111.png 1.#号截取(删左留右) echo ${var#*//} # 号是运算符,*// 表示从左边开始删除第一个 // 号及 ...

  2. Odoo 在 Ubuntu 环境下性能调优

    一.首先我们要分析影响odoo 服务器 性能的因素 CPU 目前大部分CPU在同一时间只能运行一个线程,超线程的处理器可以在同一时间处理多个线程,因此可以利用超线程特性提高系统性能. 在linux系统 ...

  3. myql 配置项

    提高数据插入速度方法 bulk_insert_buffer_size 默认:8M (8*1024*1024) 参考网址:https://stackoverflow.com/questions/2030 ...

  4. Thinkphp [美味]常用代码

    //调试开关 function _initialize () { // 调试开关 C ( 'SHOW_PAGE_TRACE', TRUE ); } //判断 IS_AJAX && $t ...

  5. clientHeight、offsetHeight 区别 笔记

    一张图 说明全部 clientHeight和clientWidth用于描述元素内尺寸,是指元素内容+内边距大小,不包括边框(低版本IE下实际包括).外边距.滚动条部分 offsetHeight和off ...

  6. 基于RBAC权限管理的后台管理系统

    在摸爬滚打中渐渐理解了RBAC权限管理是个什么玩意. RBAC的基本概念: **RBAC认为权限授权实际上是Who.What.How的问题.在RBAC模型中,who.what.how构成了访问权限三元 ...

  7. js &&操作符解析

    转载自:http://www.cnblogs.com/huchaoheng/p/4066473.html 前几天看到一个函数,百思不得其解,今天早上醒来看了本js的书,正好讲到操作符的用法,给大家分享 ...

  8. 20190719-FirstZero

    这也许也是一个成就吧? First Zero 考试 第一次 爆0 好了好了. T1 你永远不知道你在想什么. 我仿佛想出一个$\Theta(NM\log^2 N)$的$dfs$??? 蒟蒻原地爆炸 T ...

  9. html文件中script标签放在哪里?

  10. springMVC原理解析

    1:SpringMVC运行原理 2:工作流程 (1)客户端(浏览器)发送请求,直接请求到DispatcherServlet. (2)DispatcherServlet根据请求信息调用HandlerMa ...