Mysql的嵌套表查询

  嵌套SELECT语句也叫子查询,一个 SELECT 语句的查询结果能够作为另一个语句的输入值。子查询可以:

  • 出现在Where子句中,
  • 出现在from子句中,作为一个临时表使用,
  • 出现在select list中,作为一个字段值来返回。

示例

1、出现在where子句中

  • 单行子查询 :单行子查询是指子查询的返回结果只有一行数据。当主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较。
select ename,deptno,sal from emp where deptno=(select deptno from dept where loc='NEW YORK');
  • 多行子查询:多行子查询即是子查询的返回结果是多行数据。当主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。其中,IN的含义是匹配子查询结果中的任一个值即可("IN" 操作符,能够测试某个值是否在一个列表中),ALL则必须要符合子查询的所有值才可,ANY要符合子查询结果的任何一个值即可。而且须注意ALL 和ANY 操作符不能单独使用,而只能与单行比较符(=、>、< 、>= 、<= 、<>)结合使用
select stName from Student where stId in (select distinct stId from score where teId=(select teId from teacher where teName='Rona'));
select stName from Student where stId in (select distinct stId from score where score >all (select score from score where stId=(select stId from Student where stName= 'Kaka')));
select stName from Student where stId in (select distinct stId from score where score >any(select score from score where stId=(select stId from Student where stName='Kaka')));
  • 多列子查询:当是单行多列的子查询时,主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较;当是多行多列子查询时,主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。
SELECT deptno,ename,job,sal FROM EMP WHERE (deptno,sal) IN (SELECT deptno,MAX(sal) FROM EMP GROUP BY deptno);

2、内联视图:出现在where子句中,查询结果作为子表(临时表)。示例包含联合查询、嵌套查询

select job_name1,app_name,plugin_name,plugin_version from (select job_name as job_name1, app_name as app_name,plugin_name as plugin_name,plugin_version as plugin_version from plugin_check  left join jobs  on  project_name=job_name) as suibianxie where plugin_name LIKE '%graylog-logback%' AND `plugin_version` < '1.0.27.3' ORDER BY app_name

去重复操作distinct详解

1、作用于单列自然好理解,作用于多列时,是根据多列来去重的,比如下面两列是不重复的

select distinct col1,col2,col3 from table_test
a c
a b

2、且distinct并非是对多列“字符串拼接”后再去重的,而是分别作用于了每一列,比如下面两列是不重复的;下面两列拼接后是相同的,但是并不会被判断会相同

select distinct col1,col2 from table_test
rain m
rai nm

3、distinct必须放在开头

普通视图内联视图(in-line view)的关系

在select语句里的内联视图(in-line view),即SELECT * FROM (<select clause> ),例如

SELECT *
FROM ( SELECT deptno, count(*) emp_count
FROM emp
GROUP BY deptno ) emp,
dept
WHERE dept.deptno = emp.deptno;
其中,
( SELECT deptno, count(*) emp_count FROM emp GROUP BY deptno )就是所谓的内联视图(in-line view)。

在DML语句里的内联视图(in-line view),例如

nsert into (<select clause> ) values (...),其具体示例如下:

insert into (select object_id,object_name,object_type from xxx where object_id<)
values(,'testbyhao','testtype');

普通视图

我们平时说的视图指的是create view语句创建的视图类型,我们暂且称其为普通视图。例如,

CREATE  VIEW     empvu30
AS SELECT employee_id, last_name, salary
FROM employees
WHERE department_id = ;

普通视图本质上还是内联视图(in-line view),因为在执行包含普通视图的SQL语句时,普通视图都会最终转化为内联视图(in-line view)。例如,

在select语句里的普通视图,例如,

SELECT *  FROM    empvu30;
最终转化为
SELECT * FROM (SELECT employee_id, last_name, salary FROM employees WHERE department_id = );

在DML语句里的普通视图,例如,

insert into  empvu30 values(,‘jak’,);
最终转化为
insert into (SELECT employee_id, last_name, salary FROM employees WHERE department_id = ) values(,‘jak’,);

内联视图(in-line view)和子查询的区别

内联视图(in-line view)(各种类型的视图本质上都是内联视图)不同于子查询的地方在于:
子查询(可以视之为)是一个中间结果集,但是内联视图(in-line view)不可这么认为。这点可以从如

insert into (select object_id,object_name,object_type from xxx where object_id<) values (,'testbyhao','testtype');

时看出,因为一个select语句执行所得的结果集是只能读取而不能被修改的,即不支持DML操作,但是内联视图(in-line view)却又是支持DML操作,所以说从内联视图(in-line view)这个特性来看,它更像是表,只不过内联视图(in-line view)没有实际的数据,视图的全部家当,也就是你创建视图时的SELECT语句,故而我们可以将内联视图(in-line view)视为一张虚拟的表。

注释:

View
A view is a named and validated SQL query which is stored in the Oracle data dictionary. Views do not contain any data - it is just a stored query in the database that can be executed when called. One can think of a view as a virtualtable or mapping of data from one or more tables.

参见:http://www.orafaq.com/wiki/View

下面的实验证明了内联视图(in-line view)更像是表而不是子查询:
为什么说内联视图(in-line view)没有实际执行呢?看统计信息吧:
SQL> set autotrace trace exp stat
SQL> select object_id,object_name,object_type from xxx where object_id<1000;
955 rows selected.
97 consistent gets
这是一个结果集,有955 rows selected(被选择了).
SQL>create table ts as (select object_id,object_name,object_type from xxx where object_id<1000);
SQL> insert into ts values(999,'testbyhao','testtype');

1 row created.
1 consistent gets

SQL> insert into (select object_id,object_name,object_type from xxx where object_id<1000)2 values(999,'testbyhao','testtype');1 row created.1 consistent gets

从这里看出,内联视图(in-line view)的特性更像是表而不是子查询,因为insert into 内联视图(in-line view)时的统计信息说明内联视图(in-line view)没有像子查询那样实际执行而获得一个含有955行数据的结果集。insert into 内联视图(in-line view)时的统计信息显示1 row created.即新创建了一行数据在视图里,这个和insert into 表时的统计信息一样。
注释:
内联视图(in-line view)中内联的意思,在主查询语句中,内联视图(in-line view):
( SELECT deptno, count(*) emp_count FROM emp GROUP BY deptno )
是直接将其源码
( SELECT deptno, count(*) emp_count FROM emp GROUP BY deptno )嵌入主查询语句中,而普通视图,如名为empvu30的视图:
CREATE VIEW empvu30 AS SELECT  employee_id, last_name, salary FROM    employees WHERE   department_id = 30;是将视图名 empvu30嵌入主查询语句中,而不是其源码
SELECT  employee_id, last_name, salary FROM    employees WHERE   department_id = 30;
所以,内联视图(in-line view)中内联的意思就是直接将内联视图源码嵌入主查询语句里的意思。内联函数中内联的意思也是如此,即直接将内联函数的函数体源码嵌入到类中,而不是在类中只是声明了函数头,没有函数体。这样,可以避免在类中只是声明了函数头而没有函数体时要保护现场后去切换调用函数体的开销,从而提高执行速度。

参考:

1、https://www.cnblogs.com/wangshenhe/archive/2012/11/28/2792093.html

2、http://wiki.jikexueyuan.com/project/sql/sub-queries.html

3、https://blog.csdn.net/sinat_25059791/article/details/69666318

sql的嵌套查询,把一次查询的结果做为表继续进一步查询;内联视图的更多相关文章

  1. Oracle的分页查询及内联视图和函数处理

    1.Oracle的分页常用方式: select * from(select * ,ROWNUM num from table where ROWNUM<=20 ) where num>0; ...

  2. SQL 多个表之间联合查询

    非常少用join,这次学学,并备忘两篇文章! 转自:http://hcx-2008.javaeye.com/blog/285661 连接查询 通过连接运算符能够实现多个表查询.连接是关系数据库模型的主 ...

  3. mysql连表操作是先连表还是先查询条件

    mysql连表操作是先连表还是先查询条件 一.总结 一句话总结: 连表操作时:先根据查询条件和查询字段确定驱动表,确定驱动表之后就可以开始连表操作了,然后再在缓存结果中根据查询条件找符合条件的数据 1 ...

  4. sql中的内联和外联(简单用法)

    有两张表:user和department User表: CREATE TABLE `user` (    `id` int(11) NOT NULL AUTO_INCREMENT,    `name` ...

  5. sql中内联&nbsp;和外联&nbsp;区别

    sql中内联 和外联 区别 2007-05-15 17:37 这个概念一般看书不好理解.其实夜简单.有例子就简单了. 比如: 表A(主表) cardid username 16 aa 23 bb 25 ...

  6. sql:除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询

    执行sql语句: select * from ( select * from tab where ID>20 order by userID desc ) as a order by date ...

  7. [转]sql:除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询

    执行sql语句: select * from ( select * from tab where ID>20 order by userID desc ) as a order by date ...

  8. [sql Server]除非另外还指定了TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效

    今天遇到一个奇怪的问题,项目突然要从mysql切换到sql server数据库,包含order by 子句的嵌套子查询报错. 示例:select top 10 name,age,sex from ( ...

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

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

随机推荐

  1. 牛客练习赛1 A - 矩阵

    链接:https://www.nowcoder.com/acm/contest/2/A来源:牛客网 题目描述 给出一个n * m的矩阵.让你从中发现一个最大的正方形.使得这样子的正方形在矩阵中出现了至 ...

  2. Logan:美团点评的开源移动端基础日志库

    前言 Logan是美团点评集团移动端基础日志组件,这个名称是Log和An的组合,代表个体日志服务.同时Logan也是“金刚狼”大叔的名号,当然我们更希望这个产品能像金刚狼大叔一样犀利. Logan已经 ...

  3. 【Memory】chrome调试面板

    本篇文章以chrome版本67.0.3396.99为例,介绍如何使用Chrome和DevTools查找影响页面性能的内存问题,包括内存泄漏.内存膨胀和频繁的垃圾回收. 一.参考链接 https://d ...

  4. python2和python3同时安装

    现在很多项目用python2完成的,很多情况下2和3是同时存在的 大多人都是先安装了python2 安装python3: 下一步: 然后安装完成以后,去cmd控制台输入python看看安装成功了吗(用 ...

  5. Qt中文本编辑器实现语法高亮功能(Qscitinlla)

    Scintilla是一个免费.跨平台.支持语法高亮的编辑控件.它完整支持源代码的编辑和调试,包括语法高亮.错误指示.代码完成(code completion)和调用提示(call tips).能包含标 ...

  6. JS 常用库汇总收集

    本文不定期更新, 用于汇总记录一些看着 ok 的 JS 库. 库名 简介 项目地址 macy.js 仅 4 kb的 原生 流布局插件 http://macyjs.com/ Driver.js 仅 4 ...

  7. 利用Pastezort渗透win7

    下载Pastezort git clone https://github.com/ZettaHack/PasteZort.git 给Pastezort文件夹提升权限 /root/PasteZort/ ...

  8. 2 Scala基本语法

    1 变量和函数 变量: Scala 有两种变量, val 和 var. val:常量,类似于 Java 里的 final 变量.一旦初始化了, val 就不能再赋值了. va: 如同 Java 里面的 ...

  9. 鸟哥的私房菜:Bash shell(一)-Bash shell功能简介

    Bash shell系列里,由变量谈起,先讲到环境变量的功能与修改的问题, 然后会继续提到历史指令的运用.接下来,就会谈一下『数据流重导向』这个重要概念, 最后就是管线命令的利用! 一  Bash s ...

  10. 监控 Linux 系统的 7 个命令行工具

    监控 Linux 系统的 7 个命令行工具: " 深入 关于Linux最棒的一件事之一是你能深入操作系统,来探索它是如何工作的,并寻找机会来微调性能或诊断问题.这里有一些基本的命令行工具,让 ...