mysql练习题emp,dept

mysql练习题emp,deptDROP DATABASE IF EXISTS `emp`; CREATE DATABASE `emp`; USE emp; CREATE TABLE `dept`( `deptno` INT(2)

mysql练习题emp,dept

DROP DATABASE IF EXISTS `emp`;
CREATE DATABASE `emp`;
USE emp;
 CREATE TABLE `dept`(
    `deptno` INT(2) NOT NULL, 
    `dname` VARCHAR(14),
    `loc` VARCHAR(13),
    CONSTRAINT pk_dept PRIMARY KEY(deptno)
) ENGINE=INNODB DEFAULT CHARSET=utf8;
 SELECT *FROM  dept;
 INSERT INTO dept VALUES (10,"ACCOUNTING","NEW YORK"); 
INSERT INTO dept VALUES (20,"RESEARCH","DALLAS"); 
INSERT INTO dept VALUES (30,"SALES","CHICAGO");  
INSERT INTO dept VALUES (40,"OPERATIONS","BOSTON");
CREATE TABLE `emp` (
    `empno` INT(4) NOT NULL PRIMARY KEY,
    `ename` VARCHAR(10),  
    `job` VARCHAR(9),  
    `mgr` INT(4),  
    `hiredate` DATE,  
    `sal` FLOAT(7,2),  
    `comm` FLOAT(7,2),  
    `deptno` INT(2),
    CONSTRAINT fk_deptno FOREIGN KEY(deptno) REFERENCES dept(deptno)
) ENGINE=INNODB DEFAULT CHARSET=utf8;
SELECT *FROM emp;
INSERT INTO EMP VALUES (7369,"SMITH","CLERK",7902,"1980-12-17",800,NULL,20); 
INSERT INTO EMP VALUES (7499,"ALLEN","SALESMAN",7698,"1981-02-20",1600,300,30);
INSERT INTO EMP VALUES (7521,"WARD","SALESMAN",7698,"1981-02-22",1250,500,30); 
INSERT INTO EMP VALUES (7566,"JONES","MANAGER",7839,"1981-04-02",2975,NULL,20); 
INSERT INTO EMP VALUES (7654,"MARTIN","SALESMAN",7698,"1981-09-28",1250,1400,30); 
INSERT INTO EMP VALUES (7698,"BLAKE","MANAGER",7839,"1981-05-01",2850,NULL,30); 
INSERT INTO EMP VALUES (7782,"CLARK","MANAGER",7839,"1981-06-09",2450,NULL,10); 
INSERT INTO EMP VALUES (7788,"SCOTT","ANALYST",7566,"1987-07-13",3000,NULL,20); 
INSERT INTO EMP VALUES (7839,"KING","PRESIDENT",NULL,"1981-11-07",5000,NULL,10); 
INSERT INTO EMP VALUES (7844,"TURNER","SALESMAN",7698,"1981-09-08",1500,0,30); 
INSERT INTO EMP VALUES (7876,"ADAMS","CLERK",7788,"1987-07-13",1100,NULL,20); 
INSERT INTO EMP VALUES (7900,"JAMES","CLERK",7698,"1981-12-03",950,NULL,30); 
INSERT INTO EMP VALUES (7902,"FORD","ANALYST",7566,"1981-12-03",3000,NULL,20); 
INSERT INTO EMP VALUES (7934,"MILLER","CLERK",7782,"1982-01-23",1300,NULL,10);
SELECT *FROM emp;
CREATE TABLE `salgrade` (  
    `grade` INT, 
    `losal` INT,  
    `hisal` INT
) ENGINE=INNODB DEFAULT CHARSET=utf8; 
INSERT INTO SALGRADE VALUES (1,700,1200); 
INSERT INTO SALGRADE VALUES (2,1201,1400); 
INSERT INTO SALGRADE VALUES (3,1401,2000); 
INSERT INTO SALGRADE VALUES (4,2001,3000); 
INSERT INTO SALGRADE VALUES (5,3001,9999);
SELECT *FROM salgrade;
-- SQL练习训练一sal工资,comm奖金,mgr 经理编号
-- 1、 选择部门30中的雇员
SELECT *FROM emp WHERE deptno="30";
-- 2、 检索emp表中的员工姓名、月收入及部门编号
SELECT ename 姓名,sal 月收入,empno 部门编号 FROM emp;

-- 3、 检索emp表中员工姓名、及雇佣时间(雇佣时间按照yyyy-mm-dd显示)
 SELECT ename 姓名,hiredate 雇佣时间 FROM emp;
-- 4、 检索emp表中的部门编号及工种,并去掉重复行 
SELECT DISTINCT empno 部门编号,job 工种 FROM emp;
-- 5、 检索emp表中的员工姓名及全年的月收入 
SELECT ename 姓名,sal*12 年收入 FROM emp;
-- 6、 用姓名显示员工姓名,用年收入显示全年月收入。 
SELECT ename 姓名,sal*12 年收入 FROM emp;
-- 7、 检索月收入大于2000的员工姓名及月收入 
SELECT ename 姓名,sal 月收入 FROM emp WHERE sal>2000;
-- 8、 检索月收入在1000元到2000元的员工姓名、月收入及雇佣时间  
SELECT ename 姓名,sal 月收入 FROM emp WHERE sal<=2000 AND sal>=1000;
-- 9、 检索以S开头的员工姓名及月收入
SELECT ename 姓名,sal 月收入 FROM emp WHERE ename LIKE "s%";
-- 10、检索emp表中月收入是800的或是1250的员工姓名及部门编号
SELECT ename 姓名, empno 部门编号 FROM emp WHERE sal="800"OR sal="1250";
-- 11、显示在部门20中岗位是CLERK的所有雇员信息 
SELECT *FROM (SELECT *FROM emp WHERE job="CLERK") s WHERE s.deptno="20";
-- 12、显示工资高于2500或岗位为MANAGER的所有雇员信息 
SELECT *FROM emp WHERE sal>2500 OR job="MANAGER";
-- 13、检索emp表中有奖金的员工姓名、月收入及奖金 
SELECT ename 姓名,sal 月收入,comm 奖金 FROM emp WHERE comm>0;
-- 14、检索emp表中部门编号是30的员工姓名、月收入及提成,并要求其结果按月收入升序、然后按提成降序显示 
SELECT s.ename 姓名,s.sal 月收入,s.mgr 提成 FROM(SELECT *FROM emp WHERE deptno="30" ORDER BY sal ASC) s ORDER BY s.mgr DESC;
-- 15、列出所有办事员的姓名、编号和部门(姓名对不上)
SELECT  a.ename 姓名,a.empno ,b.deptno FROM dept a LEFT JOIN emp b WHERE a.ename=b.dname;
-- 17、找出部门10中所有经理和部门20中的所有办事员的详细资料
SELECT *FROM emp WHERE (deptno="10" AND job="MANAGER") OR (deptno ="20" AND job="CLERK");
-- 18、找出部门10中所有经理、部门20中所有办事员,既不是经理又不是办事员但其薪金>=2000的所有雇员的详细资料
SELECT *FROM emp WHERE (deptno="10" AND job="MANAGER") OR (deptno ="20" AND job="CLERK")OR (job NOT IN("MANAGER","CLERK") AND sal>=2000);

-- 19、找出收取奖金的雇员的不同工作
SELECT DISTINCT job 工作 FROM emp WHERE comm>0;
-- 20、找出不收取奖金或收取的奖金低于100的雇员 
SELECT ename 姓名 FROM emp WHERE comm<100 OR comm IS NULL;
-- 21、找出各月倒数第三天受雇的所有雇员
SELECT ename 各月倒数三天受雇人姓名 FROM emp WHERE DAYOFMONTH(LAST_DAY(hiredate))-DAYOFMONTH(hiredate)<=3;
SELECT LAST_DAY(hiredate) FROM emp;
SELECT DAYOFMONTH(LAST_DAY(hiredate)) FROM emp;

SELECT DAYOFMONTH(hiredate) FROM emp;

-- select DAYOFMONTH(now())


-- 22、获取当前日期所在月的最后一天
SELECT CURDATE();                       -- 获取当前日期
SELECT DATE_ADD(CURDATE(),INTERVAL -DAY(CURDATE())+1 DAY)   -- 获取本月第一天
SELECT LAST_DAY(CURDATE());   -- 获取当月最后一天
SELECT DATE_ADD(CURDATE()-DAY(CURDATE())+1,INTERVAL 1 MONTH ) -- 获取下个月的第一天
SELECT DATEDIFF(DATE_ADD(CURDATE()-DAY(CURDATE())+1,INTERVAL 1 MONTH ),DATE_ADD(CURDATE(),INTERVAL -DAY(CURDATE())+1 DAY)) FROM DUAL -- 获取当前月的天数
-- 23、找出早于25年之前受雇的雇员
SELECT *FROM emp WHERE DATE_ADD(NOW(),INTERVAL -25 YEAR)>hiredate;

-- 24、显示正好为6个字符的雇员姓名
SELECT *FROM emp WHERE ename LIKE "%______"; 
SELECT *FROM emp WHERE LENGTH(ename)="6";
-- 25、显示不带有"R"的雇员姓名
SELECT *FROM emp WHERE ename  NOT LIKE "%R%";
-- 26、显示雇员的详细资料,按姓名排序
SELECT *FROM emp ORDER BY ename;
-- 27、显示雇员姓名,根据其服务年限,将最老的雇员排在最前面 
 SELECT ename 姓名,hiredate FROM emp ORDER BY hiredate;
-- 28、显示所有雇员的姓名、工作和薪金,按工作的降序顺序排序,而工作相同时按薪金升序
SELECT t.ename 姓名,t.job 工作,t.sal 薪金 FROM(SELECT * FROM emp ORDER BY job DESC) t ORDER BY t.sal ASC;
-- 29、显示所有雇员的姓名和加入公司的年份和月份,按雇员受雇日所在月排序,将最早年份的项目排在最前面 
SELECT t.ename 姓名, YEAR(t.hiredate) 年份, MONTH(t.hiredate)月份  FROM(SELECT *FROM emp ORDER BY DAY(hiredate))t ORDER BY YEAR(t.hiredate);
-- 30、显示在一个月为30天的情况下所有雇员的日薪金
SELECT sal/30 日薪金 FROM emp WHERE  DAY(LAST_DAY(hiredate));
SELECT LAST_DAY(hiredate) FROM emp;
-- 31、找出在(任何年份的)2月受聘的所有雇员
SELECT ename 姓名,MONTH(hiredate) 月份 FROM emp WHERE MONTH(hiredate)=2;
-- 32、对于每个雇员,显示其加入公司的天数
SELECT ename 姓名,TIMESTAMPDIFF(DAY,hiredate,NOW()) 加入公司天数 FROM emp;
-- 33、显示姓名字段的任何位置,包含 "A" 的所有雇员的姓名 
SELECT SUBSTRING(ename,1,1)第一个字母,SUBSTRING(ename,2,1)第二个字母,SUBSTRING(ename,3,1)第三个字母,SUBSTRING(ename,4,1)第四个字母,SUBSTRING(ename,5,1)第六个字母,SUBSTRING(ename,6,1)第五个字母,ename 姓名 FROM emp WHERE ename LIKE "%A%";
-- 34、以年、月和日显示所有雇员的服务年限 
SELECT ename 姓名, YEAR(hiredate) 年,MONTH(hiredate)月,DAY(hiredate) 日,TIMESTAMPDIFF(YEAR,hiredate,NOW()) 服务年数 FROM emp;
 
-- 35、选择公司中有奖金 (COMM不为空,且不为0) 的员工姓名,工资和奖金比例,按工资逆排序,奖金比例逆排序.
SELECT t.ename 有奖金员工姓名,t.sal 工资,t.comm 奖金 FROM ( SELECT *FROM emp WHERE comm>0 ORDER BY sal DESC) t ORDER BY t.comm DESC; 
-- 36、选择公司中没有管理者的员工姓名及job 
SELECT ename 姓名,job 工作 FROM emp WHERE job NOT IN("MANAGER","PRESIDENT");
-- 37、选择在1987年雇用的员工的姓名和雇用时间 
SELECT ename 姓名,hiredate 雇用时间 FROM emp WHERE YEAR(hiredate)=1987;
-- 38、选择在20或10号部门工作的员工姓名和部门号 
SELECT ename 姓名,deptno 部门号 FROM  emp WHERE deptno=10 OR deptno=20;
-- 39、选择雇用时间在1981-02-01到1981-05-01之间的员工姓名,职位(job)和雇用时间,按从早到晚排序. 
SELECT ename 姓名,job 职位,hiredate 雇佣时间 FROM emp WHERE hiredate>"1981-02-01" AND hiredate<"1981-05-01";
-- 40、选择工资不在5000到12000的员工的姓名和工资 
SELECT ename 姓名,sal 工资 FROM emp WHERE NOT sal>"5000" AND sal<"12000";
-- 41、查询员工号为7934的员工的姓名和部门号 
SELECT ename 姓名,deptno 部门号 FROM emp WHERE empno IN("7934");
-- 42、查询工资大于1200的员工姓名和工资
SELECT ename 姓名,sal 工资 FROM emp WHERE sal>1200;

-- 复杂查询
-- 1.  列出与“SCOTT”从事相同工作的所有员工及部门名称,部门人数。
SELECT ename 名字,dname 部门名称,(SELECT COUNT(*) FROM emp WHERE deptno=20) 人数 FROM emp,dept WHERE emp.`job`IN(SELECT emp.`JOB` FROM emp WHERE emp.`ENAME` = "SCOTT")AND emp.`deptno`=dept.`deptno`;
SELECT COUNT(*) FROM emp WHERE deptno=20;

-- 2.  列出公司各个工资等级雇员的数量、平均工资。
SELECT salgrade.`GRADE` AS "薪资等级", COUNT(tt.`EMPNO`) AS "员工数" ,AVG(tt.sal)平均工资
FROM salgrade, 
(SELECT emp.`EMPNO`, emp.`SAL`FROM emp) AS tt WHERE tt.`SAL` >= salgrade.`LOSAL` AND tt.`SAL` <= salgrade.`HISAL`
GROUP BY salgrade.`GRADE`;
-- 3.  列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金、部门名称。
   SELECT MAX(sal) FROM emp WHERE deptno=30;
   SELECT *FROM emp WHERE sal>(SELECT MAX(sal) FROM emp WHERE deptno=30);
   SELECT c.ename 姓名,c.sal 薪金,d.`dname` 部门名称 FROM dept AS d JOIN (SELECT *FROM emp WHERE sal>(SELECT MAX(sal) FROM emp WHERE deptno=30)) AS c WHERE d.`deptno`=c.deptno; 
-- 4.  列出在每个部门工作的员工数量、平均工资和平均服务期限。
SELECT AVG(sal),(SELECT COUNT(*)FROM emp GROUP BY deptno) FROM emp ;
SELECT COUNT(*)FROM emp GROUP BY deptno;
SELECT AVG(sal)FROM emp GROUP BY deptno;
SELECT COUNT(*),AVG(sal),AVG(YEAR(NOW())-YEAR(hiredate))FROM emp GROUP BY deptno;
-- 5.  列出所有员工的姓名、部门名称和工资。
SELECT e.`ename` 姓名,d.`dname` 部门名称,e.sal 工资 FROM emp e JOIN dept d ON e.`deptno`=d.`deptno`;
-- 6.  列出所有部门的详细信息和部门人数。
SELECT d.*,COUNT(*) 部门人数 FROM dept d JOIN emp e ON e.`deptno`=d.`deptno` GROUP BY deptno;
-- 7.  列出各种工作的最低工资及从事此工作的雇员姓名。
SELECT job, MIN(sal) FROM emp  GROUP BY job;
SELECT job, MIN(sal) FROM emp  GROUP BY job;

SELECT ename FROM emp e JOIN (SELECT job, MIN(sal) FROM emp  GROUP BY job) t WHERE e.`job`=t.job AND e.`sal`=MIN(sal); 
-- 8.  列出各个部门的MANAGER(经理)的最低薪金、姓名、部门名称、部门人数。
SELECT MIN(e.sal),e.`ename` FROM emp e JOIN dept t ON e.`deptno`=t.`deptno` WHERE job IN("MANAGER") GROUP BY t.`deptno`;
SELECT e.`sal`,e.`ename`, d.`dname`,COUNT=(SELECT COUNT(*) FROM emp WHERE job IN("MANAGER")GROUP BY deptno ) FROM emp e JOIN dept d ON e.`deptno`=d.`deptno` WHERE job IN("MANAGER")
-- 9.  列出所有员工的年工资,所在部门名称,按年薪从低到高排序。
 SELECT ename, sal*12 FROM emp ORDER BY sal*12 ASC;
-- 10. 查出某个员工的上级主管及所在部门名称,并要求出这些主管中的薪水超过3000
    SELECT mgr FROM emp WHERE ename="SMITH" 
    SELECT e.ename ,d.dname FROM emp e JOIN dept d ON e.deptno=d.deptno WHERE empno=(SELECT mgr FROM emp WHERE ename="SMITH") AND e.sal>3000;
-- 11. 求出部门名称中,带‘S’字符的部门员工的工资合计、部门人数。
   SELECT deptno FROM dept WHERE dname LIKE "%S%";-- 查询部门
   SELECT SUM(sal),COUNT(*)FROM emp WHERE deptno IN(SELECT deptno FROM dept WHERE dname LIKE "%S%") GROUP BY deptno;
-- 12. 给任职日期超过40年或者在87年雇佣的雇员加薪,加薪原则:10部门增长10%,20部门增长20%,30部门增长30%,依次类推。
     SELECT *FROM emp WHERE  YEAR(NOW())-YEAR(hiredate)>40 OR YEAR(hiredate)=1987;
     SELECT YEAR(NOW())-YEAR(hiredate)FROM emp;
     SELECT IF(emp.deptno=10,sal+sal*0.1,IF(emp.`sal`=20,sal+sal*0.2,IF(emp.`deptno`=30,sal+sal*0.3,"无"))) FROM emp WHERE YEAR(NOW())-YEAR(hiredate)>40 OR YEAR(hiredate)=1987; 
-- 13. 列出至少有一个员工的所有部门的信息:
     SELECT COUNT(*)FROM emp GROUP BY deptno;
     SELECT   deptno FROM emp  ;
     SELECT *FROM emp LEFT JOIN dept ON dept.`deptno`=emp.`deptno` GROUP BY dept.`dname`  HAVING COUNT(emp.`empno`)>=5;
     SELECT dept.`DNAME` AS "部门名", COUNT(emp.`EMPNO`) AS "员工个数"
FROM dept LEFT JOIN emp ON dept.`DEPTNO` = emp.`DEPTNO`
GROUP BY dept.`DNAME` HAVING COUNT(emp.`EMPNO`) >= 5;
-- 14. 列出薪水比“SMITH”多的所有员工信息

SELECT *FROM emp WHERE emp.`SAL` > (SELECT emp.`SAL`FROM emp WHERE emp.`ENAME` = "SMITH");


-- 15. 列出所有员工的姓名以及其直接上级的姓名:
SELECT DISTINCT e.ename 员工姓名,d.ename FROM emp e JOIN (SELECT ename FROM emp WHERE empno IN(SELECT mgr FROM emp WHERE ename=ename)) d; 
SELECT mgr FROM emp WHERE ename=ename;
SELECT ename FROM emp WHERE empno IN(SELECT mgr FROM emp WHERE ename=ename);

SELECT emp.`ENAME` AS "员工名称", tt.lname AS "领导名称"
FROM emp LEFT JOIN (
    SELECT emp.`EMPNO`, emp.`ENAME` AS "lname"
    FROM emp 
    WHERE empno IN (SELECT mgr FROM emp)) AS tt ON emp.`MGR` = tt.empno;


-- 16. 列出受雇日期早于其直接上级的所有员工的编号、姓名,部门名称
SELECT t2.eno AS "编号", t2.ename AS "姓名", dept.`DNAME` AS "部门名称", t2.ehiredate AS "员工受雇日期", t2.lhiredate AS "领导受雇日期"
FROM dept
INNER JOIN 
(
    SELECT emp.`EMPNO` AS "eno", emp.`ENAME`, emp.`HIREDATE` AS "ehiredate", t1.lhiredate, emp.`DEPTNO`
    FROM 
    emp LEFT JOIN 
    (
        SELECT emp.`EMPNO` AS "lno", emp.`HIREDATE` AS "lhiredate"
        FROM emp 
        WHERE empno IN 
        (
            SELECT mgr FROM emp
        ) -- 找出所有是领导的员工no
 
    ) AS t1
    ON emp.`MGR` = t1.lno
) AS t2
ON t2.deptno = dept.`DEPTNO`
WHERE t2.ehiredate <  t2.lhiredate OR t2.lhiredate IS NULL;
-- 17. 列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门
SELECT dept.`DNAME` AS "部门名称", emp.`ENAME` AS "员工名称", emp.`JOB` AS "职位", emp.`HIREDATE` AS "入职时间", emp.`SAL` AS "薪水"
FROM dept LEFT JOIN emp ON dept.`DEPTNO` = emp.`DEPTNO`;
 
 

-- 18. 列出所有"CLERK(职员)"的姓名以及部门名称,部门的人数
SELECT emp.`ENAME` AS "姓名", dept.`DNAME` AS "部门名称", tt.emp_count AS "部门人数"
FROM emp LEFT JOIN dept ON emp.`DEPTNO` = dept.`DEPTNO`
INNER JOIN 
(
    SELECT dept.`DEPTNO`, COUNT(emp.`EMPNO`) AS "emp_count"
    FROM dept LEFT JOIN emp ON dept.`DEPTNO` = emp.`DEPTNO`
    GROUP BY dept.`DEPTNO` 
 
) AS tt
ON emp.`DEPTNO` = tt.deptno
 
WHERE emp.`JOB` = "CLERK";
-- 19. 列出最低薪金大于1500的各种工作以及从事此工作的全部雇员人数
SELECT emp.`JOB` AS "工作名称", COUNT(emp.`EMPNO`) AS "雇员人数"
FROM emp 
WHERE emp.`JOB` IN (
    SELECT emp.`JOB`
    FROM emp
    GROUP BY emp.`JOB` HAVING MIN(emp.`SAL`) >1500
)
GROUP BY emp.`JOB`;
-- 20. 列出在部门"SALES"工作的员工的姓名,假定不知道销售部的部门编号
SELECT emp.`ENAME` AS "销售部人员"
FROM emp
WHERE emp.`DEPTNO` = (
    SELECT dept.`DEPTNO`
    FROM dept
    WHERE dept.`DNAME` = "sales"
);
-- 21. 列出薪金高于公司平均薪金的所有员工,所在部门,上级领导,公司的工资等级
SELECT t1.ename AS "员工名称", dept.`DNAME` AS "部门名称", t2.ename AS "上级名称", t1.grade AS "工资等级", t1.sal AS "工资"
 
FROM 
(
    SELECT emp.`EMPNO`, emp.`DEPTNO`, emp.`ENAME`, emp.`SAL`, emp.`MGR`,salgrade.`GRADE`
    FROM emp, salgrade
    WHERE emp.`SAL` > (
        SELECT AVG(sal) AS "avg_sal"
        FROM emp
    ) AND emp.`SAL` >= salgrade.`LOSAL` AND emp.`SAL` <= salgrade.`HISAL`
) AS t1
LEFT JOIN 
(
    SELECT emp.`EMPNO` AS "mgr", emp.`ENAME` -- 注意这里是查出所有领导的empno,作为mgr编号
    FROM emp 
    WHERE emp.`EMPNO` IN 
    (
        SELECT DISTINCT(emp.`MGR`) -- 必须要distinct 不然查出来的mgr有重复,后面上层再查重复值接近笛卡尔积
        FROM emp
        WHERE mgr IS NOT NULL
    )
) AS t2
ON t1.mgr = t2.mgr
LEFT JOIN dept ON t1.deptno = dept.`DEPTNO`;
-- 22. 列出至少有一个员工的所有部门编号、名称,并统计出这些部门的平均工资、最低工资、最高工资。

-- 23. 列出薪金比“SMITH”或“ALLEN”多的所有员工的编号、姓名、部门名称、其领导姓名。
 
-- 24. 列出所有员工的编号、姓名及其直接上级的编号、姓名,显示的结果按领导年工资的降序排列。
SELECT emp.`EMPNO` AS "员工编号", emp.`ENAME` AS "员工名称", (emp.`SAL`*12) AS "年薪" 
FROM emp
ORDER BY 年薪 ASC; 
-- 25. 列出受雇日期早于其直接上级的所有员工的编号、姓名、部门名称、部门位置、部门人数。 
-- 26. 列出部门名称和这些部门的员工信息(数量、平均工资),同时列出那些没有员工的部门。
SELECT dept.`DNAME` AS "部门名称", COUNT(emp.`EMPNO`) AS "员工数量", ROUND(AVG(emp.`SAL`), 2) AS "平均工资", t2.avg_year AS "平均服务年限"
FROM dept LEFT JOIN emp ON dept.`DEPTNO` = emp.`DEPTNO`
LEFT JOIN 
(
    SELECT t1.deptno, ROUND(AVG(t1.year), 0) AS "avg_year" -- 四舍五入,保留0位小数
    FROM 
    (
        SELECT emp.`DEPTNO`, ROUND((TO_DAYS(NOW())-TO_DAYS(emp.`HIREDATE`))/366, 0) AS "year"
        FROM emp
    ) AS t1
    GROUP BY t1.deptno
) AS t2 
ON dept.`DEPTNO` = t2.deptno
GROUP BY dept.`DEPTNO`; 
-- 27. 列出所有“CLERK”(办事员)的姓名及其部门名称,部门的人数,工资等级。
SELECT emp.`ENAME` AS "姓名", dept.`DNAME` AS "部门名称", tt.emp_count AS "部门人数"
FROM emp LEFT JOIN dept ON emp.`DEPTNO` = dept.`DEPTNO`
INNER JOIN 
(
    SELECT dept.`DEPTNO`, COUNT(emp.`EMPNO`) AS "emp_count"
    FROM dept LEFT JOIN emp ON dept.`DEPTNO` = emp.`DEPTNO`
    GROUP BY dept.`DEPTNO` 
 
) AS tt
ON emp.`DEPTNO` = tt.deptno
 
WHERE emp.`JOB` = "CLERK";
-- 28. 列出最低薪金大于1500的各种工作及此从事此工作的全部雇员人数及所在部门名称、位置、平均工资。 
SELECT emp.`JOB` AS "工作名称", COUNT(emp.`EMPNO`) AS "雇员人数"
FROM emp 
WHERE emp.`JOB` IN (
    SELECT emp.`JOB`
    FROM emp
    GROUP BY emp.`JOB` HAVING MIN(emp.`SAL`) >1500
)
GROUP BY emp.`JOB`;
29. 列出在部门“SALES”(销售部)工作的员工的姓名、基本工资、雇佣日期、部门名称,假定不知道销售部的部门编号。 
30. 列出薪金高于公司平均薪金的所有员工,所在部门,上级领导,公司的工资等级。     
-- 31. 列出与“SCOTT”从事相同工作的所有员工及部门名称,部门人数。
SELECT emp.`EMPNO` AS "员工编号", emp.`ENAME` AS "员工名称", dept.`DNAME` AS "部门名称"-- , emp.`DEPTNO`
FROM emp, dept
WHERE emp.`JOB` = (
    SELECT emp.`JOB` -- 查询出SCOTT从事的职业
    FROM emp
    WHERE emp.`ENAME` = "SCOTT"
) AND emp.`ENAME` <> "SCOTT"
AND emp.`DEPTNO` = dept.`DEPTNO`;
-- 32. 查询dept表的结构
33. 检索emp表,用is a 这个字符串来连接员工姓名和工种两个字段
34. 检索emp表中有提成的员工姓名、月收入及提成。

SELECT *FROM emp WHERE deptno="20"
SELECT *FROM emp;
SELECT *FROM dept;
SELECT *FROM salgrade;

 

原文地址:https://www.cnblogs.com/zcxxcvbn/archive/2022/02/23/15929018.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5492.html

(0)
上一篇 2023-05-07
下一篇 2023-05-07

相关推荐

  • Mysql默认配置文件[通俗易懂]

    Mysql默认配置文件[通俗易懂]Mysql默认配置文件 [client] port = 3306 socket = /tmp/mysql.sock [mysql] prompt=”MySQL [d]> ” no-auto-reha…

    2023-04-01
    168
  • 使用Pycharm进行Python编程

    使用Pycharm进行Python编程Python是一种直观易学的编程语言,被广泛应用于数据分析、机器学习、网络编程等领域。而Pycharm则是一个专为Python开发者打造的集成开发环境(IDE),它提供了一整套开发工具,包括代码自动补全、调试功能、版本控制、重构等,为Python开发者提供了高效、方便的编程体验。

    2024-06-30
    47
  • Python String Capitalize: 将字符串的首字母大写

    Python String Capitalize: 将字符串的首字母大写在Python中,字符串是一个不可变的序列,因此字符串的方法都返回一个新的字符串,而不是改变原有字符串。

    2024-01-18
    102
  • Python界面长什么样子

    Python界面长什么样子Python作为一门广泛应用的编程语言,不同于其他编程语言,它具备强大的图形界面库。Python的图形界面主要采用的是Tkinter、PyQt、wxPython等库,让我们能够实现各种各样的用户界面。因此,本文将带您深入了解Python界面是如何制作的,以及它的外观是怎样的。

    2024-05-11
    71
  • MongoDB学习笔记:默认数据库与集合

    MongoDB学习笔记:默认数据库与集合本文更新于2022-01-15,使用MongoDB 4.4.5。 admin 管理员的数据库。 管理员命令只能在此数据库执行。此数据库中的用户为超级用户,可对所有数据库进行操作,并能执行管理员命令。

    2023-05-06
    155
  • Python实现插入排序

    Python实现插入排序排序是计算机科学中最基本的问题之一,也是所有算法设计的基础。一个好的排序算法可以提高对数据的搜索和处理效率。其中,插入排序是一种简单而有效的排序算法,特别适用于少量元素的排序。

    2024-07-14
    47
  • 非关系型数据库是指_非关系型数据库定义

    非关系型数据库是指_非关系型数据库定义NoSQL数据库的四大分类: 1.键值存储数据库(Key-Value) 相关产品:Redis 典型应用:内存缓存,主要用于处理大量数据的高访问负载 优势:快速查询 劣势:存储的数据缺少结构化 2.列…

    2023-02-18
    145
  • 怎样看电脑系统版本具体型号_计算机版本在哪里看

    怎样看电脑系统版本具体型号_计算机版本在哪里看1、打开电脑,点击电脑左下角的开始菜单,在弹出的菜单选项中选择“控制面板”。 2、打开控制面板,点击“系统和安全”。 3、进入系统和安全页面,点击系统下面的“查看该计算机的名称”。 4、打开新页面,…

    2023-04-13
    159

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注