mysql查询练习题

1.导入部门表
SET FOREIGN_KEY_CHECKS=0;


-- Table structure for dept


DROP TABLE IF EXISTS dept;
CREATE TABLE dept (
deptno int(11) NOT NULL,
dname varchar(30) DEFAULT NULL,
loc varchar(30) DEFAULT NULL,
PRIMARY KEY (deptno)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


-- Records of 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');

2.导入员工表
SET FOREIGN_KEY_CHECKS=0;


-- Table structure for emp


DROP TABLE IF EXISTS emp;
CREATE TABLE emp (
empno int(11) NOT NULL,
ename varchar(30) DEFAULT NULL,
job varchar(30) DEFAULT NULL,
mgr int(11) DEFAULT NULL,
hiredate datetime DEFAULT NULL,
sal decimal(10,2) DEFAULT NULL,
comm decimal(10,2) DEFAULT NULL,
deptno int(11) DEFAULT NULL,
PRIMARY KEY (empno),
KEY FK_DEPTNO (deptno),
CONSTRAINT FK_DEPTNO FOREIGN KEY (deptno) REFERENCES dept (deptno)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


-- Records of emp


INSERT INTO emp VALUES ('7369', 'SMITH', 'CLERK', '7902', '1980-12-17 00:00:00', '800.00', null, '20');
INSERT INTO emp VALUES ('7499', 'ALLEN', 'SALESMAN', '7698', '1981-02-20 00:00:00', '1600.00', '300.00', '30');
INSERT INTO emp VALUES ('7521', 'WARD', 'SALESMAN', '7698', '1981-02-22 00:00:00', '1250.00', '500.00', '30');
INSERT INTO emp VALUES ('7566', 'JONES', 'MANAGER', '7839', '1981-04-02 00:00:00', '2975.00', null, '20');
INSERT INTO emp VALUES ('7654', 'MARTIN', 'SALESMAN', '7698', '1981-09-28 00:00:00', '1250.00', '1400.00', '30');
INSERT INTO emp VALUES ('7698', 'BLAKE', 'MANAGER', '7839', '1981-05-01 00:00:00', '2850.00', null, '30');
INSERT INTO emp VALUES ('7782', 'CLARK', 'MANAGER', '7839', '1981-06-09 00:00:00', '2450.00', null, '10');
INSERT INTO emp VALUES ('7788', 'SCOTT', 'ANALYST', '7566', '1987-04-19 00:00:00', '3000.00', null, '20');
INSERT INTO emp VALUES ('7839', 'KING', 'PRESIDENT', null, '1981-11-17 00:00:00', '5000.00', null, '10');
INSERT INTO emp VALUES ('7844', 'TURNER', 'SALESMAN', '7698', '1981-09-08 00:00:00', '1500.00', '0.00', '30');
INSERT INTO emp VALUES ('7876', 'ADAMS', 'CLERK', '7788', '1987-05-23 00:00:00', '1100.00', null, '20');
INSERT INTO emp VALUES ('7900', 'JAMES', 'CLERK', '7698', '1981-12-03 00:00:00', '950.00', null, '30');
INSERT INTO emp VALUES ('7902', 'FORD', 'ANALYST', '7566', '1981-12-03 00:00:00', '3000.00', null, '20');
INSERT INTO emp VALUES ('7934', 'MILLER', 'CLERK', '7782', '1982-01-23 00:00:00', '1300.00', null, '10');

3.练习题

use test001;
show tables;

1.列出至少有一个员工的所有部门

select dept.dname FROM dept GROUP BY deptno HAVING (SELECT COUNT(1) c FROM emp WHERE emp.deptno = dept.deptno ) > 3;

select d.dname from emp e,dept d where e.deptno = d.deptno group by d.deptno having count(1) >1 ;

select d.dname from emp right join dept d on emp.deptno = d.deptno group by d.dname having count(1) >1;

select ed.dname from (select e.ename,d.dname from emp e ,dept d where e.deptno = d.deptno) ed group by ed.dname having count(ed.dname) >3;

2.列出薪金比 smith多多员工

select ename from emp where sal > (select sal from emp where ename='ALLEN');

3.列出员工姓名和上级姓名

select e1.ename 员工,e2.ename 经理 from emp e1, emp e2 where e1.mgr = e2.empno;

4.列出受雇日期早于直接上级的所有员工

select e1.ename 员工,e1.hiredate,e2.ename,e2.hiredate from emp e1,emp e2 where e1.mgr = e2.empno and e1.hiredate<e2.hiredate;

select e1.ename 员工 from emp e1,emp e2 where e1.mgr = e2.empno and e1.hiredate<e2.hiredate;

select e1.ename 员工 from emp e1 join emp e2 on e1.mgr = e2.empno and e1.hiredate<e2.hiredate;;

5.列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门

select d.dname,emp.* from emp right join dept d on emp.deptno = d.deptno order by empno;
select dname,e.* from dept left join emp e on dept.deptno = e.deptno order by empno;

6.列出所有 clerk 岗位的姓名及其部门名称

select ename,dname from emp join dept d on emp.deptno = d.deptno and job='clerk';

7.列出最低薪金大于1500的各种工作

select job from emp group by job having max(sal) >1500;

8.列出在部门sales工作的员工姓名

select ename from emp where deptno = (select deptno from dept where dname='SALES');
select ename from emp inner join dept d on emp.deptno = d.deptno where dname='sales';

9.列出薪金高于公司平均薪金的所有员工

select * from emp where sal > (select avg(sal) from emp);

10.列出与 scott 从事相同工作的所有员工,排除自己

select * from emp where job = (select job from emp where ename='scott') and ename <> 'scott';

11. 列出薪金等于部门30中员工的薪金的所有员工姓名和薪金

select ename,sal,deptno from emp where sal <any (select sal from emp where deptno =30) and deptno <> 30;

12.列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金

select ename,sal from emp where sal > (select max(sal) from emp where deptno = 30);

13.列出在每个部门工作的员工数量,平均工资,平均服务期限

select avg(sal) 平均工资,count(1) 员工数量, avg(datediff(sysdate(),hiredate) / 365) 平均年限 from emp group by deptno;

14.列出所有员工的姓名,部门名称,工资

select ename,(select dname from dept where dept.deptno=emp.deptno) 部门,sal from emp order by sal;
select e.ename,d.dname,e.sal from emp e, dept d where e.deptno = d.deptno order by e.sal;

15.列出所有部门到详细信息和部门人数

select *,(select count(1) from emp where emp.deptno = dept.deptno group by dept.deptno) 人数 from dept;

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容

  • 表结构 DROP DATABASE IF EXISTS test1; CREATE DATABASE test1;...
    玩大数据的小轩阅读 6,508评论 0 0
  • 引出 •请思考如下问题? –查询所有员工的每个月工资总和,平均工资? –查询工资最高和最低的工资是多少? –查询公...
    C_cole阅读 7,287评论 0 3
  • 目标 聚合函数 分组函数 子查询 多行子查询 引出 •请思考如下问题? –查询所有员工的每个月工资总和,平均工资?...
    wqjcarnation阅读 4,150评论 0 6
  • 1.简介 数据存储有哪些方式?电子表格,纸质文件,数据库。 那么究竟什么是关系型数据库? 目前对数据库的分类主要是...
    乔震阅读 1,712评论 0 2
  • 若在先秦的江南水乡,能足够的幸运,在萋萋芳草里抬头,隔着悠悠河水,看见他。 最好是烟雨茫茫,蒹葭苍苍,一袭杏花雪,...
    车月2017阅读 547评论 0 3