【MySQL】复合查询

本文详细介绍了MySQL的复合查询,包括多表查询、自连接和子查询的不同类型,如单行、多行、多列子查询,并在from子句中使用子查询以及合并查询(union和union all)。通过示例展示了如何在实际开发中应用这些查询技术。
摘要由CSDN通过智能技术生成

前面我们讲解的mysql表的查询都是对一张表进行查询,在实际开发中这远远不够。

1.多表查询

实际开发中往往数据来自不同的表,所以需要多表查询。本节我们用一个简单的公司管理系统,有三张表EMP,DEPT,SALGRADE来演示如何进行多表查询。
示例
显示雇员名、雇员工资以及所在部门的名字因为上面的数据来自EMP和DEPT表,因此要联合查询
在这里插入图片描述
其实我们只要emp表中的deptno = dept表中的deptno字段的记录

select EMP.ename, EMP.sal, DEPT.dname from EMP, DEPT where EMP.deptno = DEPT.deptno;

显示部门号为10的部门名,员工名和工资

select ename, sal,dname from EMP, DEPT where EMP.deptno=DEPT.deptno and DEPT.deptno= 10;

显示各个员工的姓名,工资,及工资级别

select ename, sal, grade from EMP, SALGRADE where EMP.sal between losal and hisal;

2.自连接

自连接是指在同一张表连接查询
示例
显示员工FORD的上级领导的编号和姓名(mgr是员工领导的编号–empno)
使用的子查询

select empno,ename from emp where emp.empno=(select mgr from emp where
ename='FORD');

使用多表查询(自查询)


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值