查询部门(包含子部门)员工

部门表
 
CREATE TABLE `department` (
  `ID` bigint(20) NOT NULL AUTO_INCREMENT,
  `NAME` varchar(50) DEFAULT NULL,
  `SORTNUM` varchar(50) DEFAULT NULL,
  `LEVEL` int(11) DEFAULT NULL,
  `NUMBER` varchar(50) DEFAULT NULL,
  `STATE` int(11) DEFAULT NULL,
  PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='部门表';


员工表:

CREATE TABLE `employee` (
  `ID` bigint(20) NOT NULL AUTO_INCREMENT,
  `NAME` varchar(50) DEFAULT NULL,
  `EMPNO` varchar(50) DEFAULT NULL,
  `JOBSTATE` int(11) DEFAULT NULL,
  `STATE` int(11) DEFAULT NULL,
  `SEX` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='员工表';

部门关系表:

CREATE TABLE `department_relations` (
  `ID` bigint(20) NOT NULL AUTO_INCREMENT,
  `PID` int(11) NOT NULL,
  `CID` int(11) NOT NULL,
  `STATE` int(11) DEFAULT NULL,
  PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 COMMENT='部门关系表';


部门-员工关系表

CREATE TABLE `employee_department` (
  `ID` bigint(20) NOT NULL AUTO_INCREMENT,
  `EID` int(11) NOT NULL,
  `DID` int(11) NOT NULL,
  `STATE` int(11) DEFAULT NULL,
  `RID` int(11) DEFAULT NULL,
  PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='员工部门关联表';


创建函数getChildLst:用于查出部门下的所有子部门

CREATE DEFINER=`root`@`localhost` FUNCTION `getChildLst`(rootId INT) RETURNS varchar(1000) CHARSET utf8
BEGIN 
  DECLARE sTemp VARCHAR(1000); 
  DECLARE sTempChd VARCHAR(1000); 
  SET sTemp = '$'; 
  SET sTempChd =cast(rootId as CHAR);  
  WHILE sTempChd is not null DO     
  SET sTemp = concat(sTemp,',',sTempChd); 
       SELECT group_concat(cid) INTO sTempChd FROM department_relations where FIND_IN_SET(pid,sTempChd)>0; 
       END WHILE; 
       RETURN sTemp; 
  END
;;
DELIMITER ;


输入语句:

select getChildLst(1);

可以查出该部门下的所有子部门(包括该部门)

 

查出该部门下所有员工(包括子部门)


SELECT e.NAME AS ename ,d.ID AS did ,d.NAME AS dname FROM employee e
LEFT JOIN employee_department ed ON ed.STATE=0
LEFT JOIN department d ON d.STATE=0
WHERE e.STATE=0 AND FIND_IN_SET(ed.DID,getChildLst(3))
AND ed.EID=e.ID AND d.ID=ed.DID


 

 

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以用以下SQL语句:SELECT department, COUNT(*) AS total FROM employees INNER JOIN departments ON employees.department_id = departments.department_id GROUP BY department; ### 回答2: 在SQL Server 2008中,要查询部门部门的人数,需要使用递归查询的方法。假设有两个表格,一个是部门表(department),包含部门编号(dept_id)和部门名称(dept_name);另一个是员工表(employee),包含员工编号(emp_id)、员工姓名(emp_name)和所属部门编号(dept_id)。 首先,我们需要创建一个递归查询的公用表表达式(CTE)。在CTE中,我们定义一个递归部分,用于查询直属部门的人数,并将其作为结果集的一部分返回。然后,我们使用递归部分来连接自身,查询下一级部门的人数,直到所有部门都被覆盖。 下面是递归查询的SQL语句: WITH RecursiveCTE AS ( SELECT dept_id, dept_name, 0 AS level FROM department WHERE dept_id = '顶层部门编号' -- 指定顶层部门编号 UNION ALL SELECT d.dept_id, d.dept_name, r.level + 1 FROM department d INNER JOIN RecursiveCTE r ON d.parent_dept_id = r.dept_id ) SELECT dept_id, dept_name, COUNT(e.emp_id) AS total_employees FROM RecursiveCTE r LEFT JOIN employee e ON r.dept_id = e.dept_id GROUP BY dept_id, dept_name; 以上SQL语句中,我们首先指定了顶层部门编号,然后使用了UNION操作符将其与递归部分连接起来。在递归部分中,我们连接了部门表自身,并使用INNER JOIN关键字将递归查询的结果与部门表进行连接。最后,我们使用LEFT JOIN关键字将递归查询的结果与员工表进行连接,并使用COUNT函数计算每个部门及其部门的人数。 执行以上SQL语句后,将会返回包含部门编号(dept_id)、部门名称(dept_name)和人数(total_employees)的结果集,其中人数表示该部门及其部门的所有员工的数量。 需要特别注意的是,以上SQL语句假设部门表中包含一个字段(parent_dept_id)用于表示部门的上级部门。如果部门表结构有所不同,请相应修改SQL语句中的字段名。 ### 回答3: 要查询部门部门人数,可以使用递归查询来实现。 首先,假设我们有两个表:部门表(Department)和员工表(Employee),它们的结构如下: 部门表(Department): - 部门ID(DepartmentID) - 部门名称(DepartmentName) - 上级部门ID(ParentDepartmentID) 员工表(Employee): - 员工ID(EmployeeID) - 员工姓名(EmployeeName) - 所属部门ID(DepartmentID) 现在,我们需要查询每个部门及其部门的人数。下面是一种实现方式: 1. 首先,我们以部门表为基准,使用递归查询来获取每个部门部门ID,可以编写如下SQL语句: ```sql WITH CTE AS ( SELECT DepartmentID, ParentDepartmentID FROM Department WHERE DepartmentID = @DepartmentID -- 设定初始部门ID UNION ALL SELECT D.DepartmentID, D.ParentDepartmentID FROM Department D INNER JOIN CTE C ON C.DepartmentID = D.ParentDepartmentID ) SELECT DepartmentID FROM CTE ``` 2. 接下来,我们可以将上面的查询结果作为查询,并使用COUNT函数来统计每个部门及其部门的人数。完整的查询语句如下: ```sql WITH CTE AS ( SELECT DepartmentID, ParentDepartmentID FROM Department WHERE DepartmentID = @DepartmentID -- 设定初始部门ID UNION ALL SELECT D.DepartmentID, D.ParentDepartmentID FROM Department D INNER JOIN CTE C ON C.DepartmentID = D.ParentDepartmentID ) SELECT D.DepartmentID, D.DepartmentName, COUNT(E.EmployeeID) AS EmployeeCount FROM CTE C INNER JOIN Department D ON C.DepartmentID = D.DepartmentID LEFT JOIN Employee E ON D.DepartmentID = E.DepartmentID GROUP BY D.DepartmentID, D.DepartmentName ``` 以上查询将返回部门ID(DepartmentID),部门名称(DepartmentName)以及每个部门及其部门的人数(EmployeeCount)。 注意:在实际使用中,请根据实际情况修改表名、字段名以及设定初始部门ID的方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值