|
多表查询案例
数据环境准备
- create table salgrade(
- grade int,
- losal int,
- hisal int
- ) comment '薪资等级表';
- insert into salgrade values (1,0,3000);
- insert into salgrade values (2,3001,5000);
- insert into salgrade values (3,5001,8000);
- insert into salgrade values (4,8001,10000);
- insert into salgrade values (5,10001,15000);
- insert into salgrade values (6,15001,20000);
- insert into salgrade values (7,20001,25000);
- insert into salgrade values (8,25001,30000);
复制代码 在这个案例中,我们主要运用上面所讲解的多表查询的语法,完成以下的12个需求即可,而这里主要涉及到的表就三张:emp员工表、dept部门表、salgrade薪资等级表 。
查询员工的姓名、年龄、职位、部门信息 (隐式内连接)
表: emp , dept
连接条件: emp.dept_id = dept.id- select e.name , e.age , e.job , d.name from emp e , dept d where e.dept_id = d.id;
复制代码
查询年龄小于30岁的员工的姓名、年龄、职位、部门信息(显式内连接)
表: emp , dept
连接条件: emp.dept_id = dept.id- select e.name , e.age , e.job , d.name from emp e inner join dept d on e.dept_id =d.id where e.age < 30;
复制代码
查询拥有员工的部门ID、部门名称
表: emp , dept
连接条件: emp.dept_id = dept.id- select distinct d.id , d.name from emp e , dept d where e.dept_id = d.id;
复制代码
查询所有年龄大于40岁的员工, 及其归属的部门名称; 如果员工没有分配部门, 也需要展示出来(外连接)
表: emp , dept
连接条件: emp.dept_id = dept.id- select e.*, d.name from emp e left join dept d on e.dept_id = d.id where e.age >40 ;
复制代码
查询所有员工的工资等级
表: emp , salgrade
连接条件 : emp.salary >= salgrade.losal and emp.salary <= salgrade.hisal- -- 方式一
- select e.* , s.grade , s.losal, s.hisal from emp e , salgrade s where e.salary >=
- s.losal and e.salary <= s.hisal;
- -- 方式二
- select e.* , s.grade , s.losal, s.hisal from emp e , salgrade s where e.salary
- between s.losal and s.hisal;
复制代码
到此这篇关于MySQL基础之多表查询案例分享的文章就介绍到这了,更多相关MySQL多表查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
来源:https://www.jb51.net/article/266108.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
x
|