获得审批人的id
//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的更多相关文章
- 关于OA流程相关数据表的设计
一.前言 近期有些同学问起流程的表设计,终于有时间能写下博客,并整理下之前所发布的文章. 之前的文章讲到的表设计,没有给全且还存在漏洞,在这里向各位同学表示歉意.这是我个人最新领悟的一些流程思维,欢迎 ...
- flowable的多人会签和一票否决
项目结构: 接下来代码: Duorenhuiqian.bpmn20.xml: <?xml version="1.0" encoding="UTF-8"?& ...
- 关于全局ID,雪花(snowflake)算法的说明
上次简单的说一下:http://www.cnblogs.com/dunitian/p/6041745.html#uid C#版本的国外朋友已经封装了,大家可以去看看:https://github.co ...
- 有朋友问了数据库ID不连续,怎么获取上一篇和下一篇的文章?(不是所有情况都适用)
呃 (⊙o⊙)…,逆天好久没写SQL了,EF用的时间长了,SQL都不怎么熟悉了......[SQL水平比较菜,大牛勿喷] 方法很多种,说个最常见的处理 因为id是自增长的,所以一般情况下下一篇文章的I ...
- 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 错误. 总结一下发生错误的原因,一般的 ...
- SharePoint 2013: A feature with ID has already been installed in this farm
使用Visual Studio 2013创建一个可视web 部件,当右击项目选择"部署"时报错: "Error occurred in deployment step ' ...
- ILJMALL project过程中遇到Fragment嵌套问题:IllegalArgumentException: Binary XML file line #23: Duplicate id
出现场景:当点击"分类"再返回"首页"时,发生error退出 BUG描述:Caused by: java.lang.IllegalArgumentExcep ...
- thinkphp-无限分类下根据任意部门获取顶级部门ID
根据所得到的部门编号获取顶级部门ID: 参数 - department_id 表格组织架构: tab_departments department_id parent_id name 1 1 顶级 2 ...
- 分布式唯一ID生成服务
SNService是一款基于分布式的唯一ID生成服务,主要用于提供大数量业务数据建立唯一ID的需要;服务提供最低10K/s的唯一ID请求处理.如果你部署服务的CPU资源达到4核的情况下那该服务最低可以 ...
随机推荐
- Python 字符串与二进制串的相互转换
def encode(s): return ' '.join([bin(ord(c)).replace('0b', '') for c in s]) def decode(s): return ''. ...
- Delphi 设计模式:《HeadFirst设计模式》Delphi7代码---命令模式之SimpleRemoteWithUndoTest[转]
命令模式可以很轻松的实现撤销(Undo)功能. 命令的接受者: 1unit uReceiveObject; 2 3interface 4 5type 6 TLight = class(T ...
- 磁力搜索网站 BT torrent search engine 推荐 2019/12/25日更新
btkitty 知名的BT磁力搜索,资源很多,中文友好 btdb 知名的BT磁力搜索,资源很多,中文友好 838888 不错的 BT 磁力搜索引擎,资源很多,中文友好 idope.se 资源丰富的BT ...
- Lab2 新增的细节
entry.S 新增加了这个入口函数 bootloader 加载完成后 将执行 kern_entry 而非lab1 中的kern_init defs.h 使用了 ({})宏定义的方式,并且执行了一行定 ...
- Leetcode59. Spiral Matrix II螺旋矩阵2
给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, 4 ], [ 7, 6, ...
- 基于keras中IMDB的文本分类 demo
本次demo主题是使用keras对IMDB影评进行文本分类: import tensorflow as tf from tensorflow import keras import numpy a ...
- twisted(转)
reactor.protocol 这两个类都在 twisted.internet 命名空间中 reactor对象是Twisted编程当中的第一步,它就是一个反应器,专门负责与服务端的连接以及监听与服务 ...
- jquery文字上下滚动--单行 批量多行 文字图片上下翻滚 | 多行滚动
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 在VMware安装Windows server 2003操作系统帮助文档
在VMware上安装Windows server 2003操作系统,及VMware上三种网络连接模式(以VMware 10为例) 一.在Windows上安装VMware 10虚拟机软件 1.首先在Wi ...
- Python 匹配IP地址的正则表达式