多张表联合起来查询即为连接查询,可分为:

  • 内连接:等值连接、非等值连接、自连接
  • 外连接:右外连接、左外连接

也就是先把多张表通过某种指定条件用join...on...语法连接起来,然后再进行where... group by... having等条件查询。

内连接中的等值连接

// 从emp表中查询ename,从dept表中查询员工所在的部门名称,即dname

mysql> select e.ename as employee,d.dname as department
-> from emp e
-> inner join dept d
-> on e.deptno=d.deptno;

其中inner可以省略

内连接中的非等值连接

// 从emp表中查询ename,从salgrade表中查询员工薪资等级

mysql> select e.ename employee,s.grade
-> from emp e
-> join salgrade s
-> on e.sal between s.losal and s.hisal;

内连接中的自连接,也就是自己相当于多张表

// 从emp表中查询ename和员工的领导的名字

mysql> select e.ename employee,l.ename leader
-> from emp e
-> join emp l
-> on e.mgr=l.empno;

在该查询结果中,不包括没有领导的员工

外连接中表有主次之分,而内连接中表没有主次之分。主表就是查询其中的全部数据,关联查询此表中的数据。右外连接表示join右侧的表是主表,左外连接则join左侧的是主表

// 从emp表中查询ename和员工领导的名字,没有领导的员工也要包括

mysql> select e.ename employee,l.ename leader
-> from emp e
-> left outer join emp l
-> on e.mgr=l.empno;

可以查询到emp表中的全部员工,没有领导的则leader字段显示NULL,上述语句可以改写为右连接,其中的outer可以省略。

mysql> select e.ename employee,l.ename leader
-> from emp l
-> right join emp e
-> on e.mgr=l.empno;

可见,外连接查询的结果的数量>=内连接的查询结果的数量。一条SQL语句中内连接和外连接可以同时存在。

// 从emp表中查询全部员工名字、领导名字,所在部门名字、薪资等级

mysql> select e.ename as employee,l.ename as leader,d.dname as dept,s.grade
-> from emp e
-> join dept d
-> on e.deptno=d.deptno
-> join salgrade s
-> on e.sal between s.losal and s.hisal
-> left join emp l
-> on e.mgr=l.empno;

上述join...on..语句的顺序不重要,也就是说

mysql> select e.ename as employee, l.ename as leader,d.dname as dept,s.grade
-> from emp e
-> left join emp l
-> on e.mgr=l.empno
-> join dept d
-> on e.deptno=d.deptno
-> join salgrade s
-> on e.sal between s.losal and s.hisal;

查询出来的结果一样,只是顺序不一样。

子查询即查询语句中嵌套查询语句

where子句中嵌套select:

// 从emp表中查询薪资大于平均薪资的员工姓名和其薪资

mysql> select ename as name,sal as salary
-> from emp
-> where sal>(select avg(sal) from emp);

from子句中嵌套select,可以把子查询的结果当作一张临时表

// 从emp和salgrade表中查询不同岗位的平均薪资和薪资等级

mysql> select t.job,t.avgsal,s.grade
-> from (select job,avg(sal) as avgsal from emp group by job) as t
-> join salgrade s
-> on t.avgsal between s.losal and s.hisal;

注意,这里最好给子查询的临时表的查询字段都取个别名。

此外,union用于合并查询结果集

mysql> select ename,job from emp where job='MANAGER'
-> union
-> select ename,job from emp where job='SALESMAN';

mysql> select ename,job from emp where job='MANAGER' or job='SALESMAN';

查询结果一样,但是使用union的效率更高。

limit用于分页查询,即依照条件取出部分查询结果

mysql> select ename,sal from emp order by sal desc limit 2,3;

其中2是起始位置,0时可以省略,3是取出的结果数量。

mysql> select ename,sal from emp order by sal desc limit 5;

limit (pageNo-1)*pageSize, pageSize;

MySQL常用查询命令(连接查询&子查询)的更多相关文章

  1. mysql的联合,连接,子查询

  2. MySQL数据库学习笔记(六)----MySQL多表查询之外键、表连接、子查询、索引

    本章主要内容: 一.外键 二.表连接 三.子查询 四.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复 ...

  3. MySQL多表查询之外键、表连接、子查询、索引

    MySQL多表查询之外键.表连接.子查询.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复的,不允许为 ...

  4. MySQL数据库学习笔记----MySQL多表查询之外键、表连接、子查询、索引

    本章主要内容: 一.外键 二.表连接 三.子查询 四.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复 ...

  5. mysql学习笔记-- 多表查询之外键、表连接、子查询、索引

    本章主要内容: 一.外键 二.表连接 三.子查询 四.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复 ...

  6. mysql表查询、多表查询(增强查询的使用)子查询、合并查询,外连接,mysql5种约束,自增长

    一.查询加强 1.在mysql中,日期类型可以直接比较,需要注意格式 2.%:表示0到多个字符, _:表示单个字符 exp:显示第二个字符为大写O的所有员工的姓名和工资 select  name fr ...

  7. MySQL 子查询(四)子查询的优化、将子查询重写为连接

    MySQL 5.7 ref ——13.2.10.10优化子查询 十.子查询的优化 开发正在进行中,因此从长远来看,没有什么优化建议是可靠的.以下列表提供了一些您可能想要使用的有趣技巧.See also ...

  8. MS sql server 基础知识回顾(二)-表连接和子查询

    五.表连接 当数据表中存在许多重复的冗余信息时,就要考虑将这些信息建在另一张新表中,在新表中为原表设置好外键,在进行数据查询的时候,就要使用到连接了,表连接就好像两根线,线的两端分别连接两张表的不同字 ...

  9. mysql加强(6)~子查询简单介绍、子查询分类

    一.子查询简单介绍 1.什么是子查询? 一个查询之中嵌套了其他的若干查询. 在使用select 语句查询时,有时候where的查询条件中的限制条件不是一个确定的值,而是一个来自于另一个查询的结果. 子 ...

  10. ylb:SQL 表的高级查询-多表连接和子查询

    ylbtech-SQL Server: SQL Server-表的高级查询-多表连接和子查询 SQL Server 表的高级查询-多表连接和子查询. 1,ylb:表的高级查询-多表连接和子查询 返回顶 ...

随机推荐

  1. Java 实现订单未支付超时自动取消

    在电商上购买商品后,如果在下单而又没有支付的情况下,一般提示30分钟完成支付,否则订单自动.比如在京东下单为完成支付: 超过24小时,就会自动取消订单,下面使用 Java 定时器实现超时取消订单功能. ...

  2. Caffeine缓存 最快缓存 内存缓存

    一.序言 Caffeine是一个进程内部缓存框架. 对比Guava Cache Caffeine是在Guava Cache的基础上做一层封装,性能有明显提高,二者同属于内存级本地缓存.使用Caffei ...

  3. SSL证书,IIS7、IIS8,http自动跳转到HTTPS

    安装"URL REWRITE2 " 伪静态模块,IIS7需要先确认是否安装 "URL REWRITE2 " 伪静态模块 , 如果您已经安装可以跳过 下载地址:h ...

  4. js获取 url?后面的参数取值

    function GetRequest() {     var url = location.search; //获取url中"?"符后的字串     var theRequest ...

  5. 手写一个线程池,带你学习ThreadPoolExecutor线程池实现原理

    摘要:从手写线程池开始,逐步的分析这些代码在Java的线程池中是如何实现的. 本文分享自华为云社区<手写线程池,对照学习ThreadPoolExecutor线程池实现原理!>,作者:小傅哥 ...

  6. swoole错误“Uncaught Error: Class 'swoole_server' not found”的解决办法

    如果你在执行swoole对应文件时,报下面的错误, PHP Fatal error: Uncaught Error: Class 'swoole_server' not found in /mnt/w ...

  7. 《PHP程序员面试笔试宝典》——如何克服面试中紧张的情绪?

    本文摘自<PHP程序员面试笔试宝典>. PHP面试技巧分享,PHP面试题,PHP宝典尽在"琉忆编程库". 面试的成功与否,往小的方面讲,直接关系到求职者的工作问题,往大 ...

  8. Kubernetes:健康检查

    Blog:博客园 个人 应用在运行过程中难免会出现错误,如程序异常.软件异常.硬件故障.网络故障等.因此,系统通过一些手段来判断应用是否运行正常,这些手段称之为健康检查(诊断). 前置知识 回顾一下P ...

  9. 3、前端--伪元素选择器、选择器优先级、字体、背景、边框、display、盒子模型

    伪元素选择器 # 首字调整>>>:也是一种文档布局的方式 p:first-letter { font-size: 48px; /*字体大小*/ color: red; } # 在文本 ...

  10. Solution -「多校联训」数学考试

    \(\mathcal{Description}\)   Link.   给定 \(n\) 个函数,第 \(i\) 个有 \(f_i(x)=a_ix^3+b_ix^2+cx_i+d~(x\in[l_i, ...