1. Select- subquery子查询

子查询:是将一条查询语句嵌套在另一条查询语句之中。

2. 案例

  需求:查询获得代课天数最多的那个老师的信息。

思路:先获得最多的代课天数是多少天,然后再判断哪个老师的代课天数和最大值是一样的。MySQL允许将上面的查询结果,作为一个值来使用。

即:

var1 = Select max(days) from teacher_class;/* 保存起来 */

Select  t_name,gender from teacher_class where days = var1;

Select  t_name,gender from teacher_class where days = ( Select max(days) from  teacher_class )

3. 子查询详解:

上面2中使用到就是子查询,子查询需要使用括号括起来。

(1)子查询的分类:

分类标准:

    • 子查询使用的结构:exists型,where型,from型

    • 子查询返回值形式:(1)单一值 (2)一列 (3)多列 (4)多行多列

                 

(2)标量子查询:

获得一个值之后,使用关系运算符,进行判断。

=   >    <    <=    >=    !=    

比如:Select t_name,gender from teacher_class where days < ( Select  max(days)  from  teacher_class );      

(3)列子查询:

获得一列 ,通常是多个行的一列值。

需求:获得所有带过0228班的讲师信息。

思路:先获得0228班讲师的姓名,再利用这姓名查询其所有的班记录。

select  t_name  from teacher_class  where  c_name ='php0228';

select  t_name,c_name,days from teacher_class where  t_name  in ( select  t_name  from teacher_class  where  c_name ='php0228' );

注意:

• 返回一列。

• 使用in / not in 

• 还可以使用其他的集合操作符:

       Any(集合):集合中的任何一个

       = any(集合):等于集合中的任何一个即可。等同与in

       all(集合):集合中所有的元素。

       !=all(集合):不等于集合中的任何一个即可。等同与 not in

      Some(集合):集合中的一些

--> 使用 in

--> 使用 any

--> 使用 !=any

!=any不等于集合中的任意一个就可以(注意不是要求和集合中所有的元素不相等),只要与集合中的一些元素不相等即可。

注意 !=any不是 not in

总结:

• = any   ----- in

• != all    ----- not in

• Some 和 any 同义词

                 

(4)行子查询:

使用 limit 1

行子查询案例:

在参与比较的时候,使用括号可以构建一行(field1, field2)

select t_name, gender,c_name  from teacher_class  where (gender,c_name) = (select  distinct  gender,c_name  from teacher_class where t_name='李白' and c_name='php0115');

这时候要求查询结果返回一行,如下:

select t_name, gender,c_name  from teacher_class  where (gender,c_name) = (select  distinct  gender,c_name  from teacher_class where t_name='李白' and c_name='php0115'  limit 1);

(5)表子查询:

通常用在from型语句中。

select * from (select  t_name ,c_name,days  from  teacher_class  where  days > 15);

在from子句中内,要求使用一个表,而不是一个结构,应该给这个查询结果起名,别名。

select * from (select  t_name ,c_name,days  from  teacher_class  where  days > 15) as  temp;

在上面的基础上,添加查询条件,如下:

select * from (select  t_name ,c_name,days  from  teacher_class  where  days > 15) as  temp  where  t_name  like '李%';

再次添加查询条件:

select  teacher  from (select  t_name  as  teacher ,c_name,days  from  teacher_class  where  days > 15) as  temp  where  teacher like '李%';

MySQL(18):Select- subquery子查询的更多相关文章

  1. mysql update不支持子查询更新

    先看示例: SELECT uin,account,password,create_user_uin_tree FROM sys_user 结果: 表中的create_user_uin_tree标识该条 ...

  2. SELECT使用子查询

    SELECT使用子查询   SELECT使用子查询,该子查询会执行多次,  次数是由记录数量决定.效率比较低,不推荐使用.  //查询部门编号,工资大于等于2000的人数,  //工资小于2000的人 ...

  3. subquery 子查询

    #encoding: utf-8 from sqlalchemy import create_engine,Column,Integer,String,Float,func,and_,or_,Enum ...

  4. MySQL(八)子查询和分组查询

    一.子查询 1.子查询(subquery):嵌套在其他查询中的查询. 例如:select user_id from usertable where mobile_no in (select mobil ...

  5. Mysql - 性能优化之子查询

    记得在做项目的时候, 听到过一句话, 尽量不要使用子查询, 那么这一篇就来看一下, 这句话是否是正确的. 那在这之前, 需要介绍一些概念性东西和mysql对语句的大致处理. 当Mysql Server ...

  6. MySQL 使用JOIN优化子查询

    1.数据准备 mysql> select * from student; +----+--------+----------+---------+-------------+ | id | na ...

  7. mysql sql_safe_updates 不支持子查询的更新。

    考虑到开发人员有时候不小心误更新数据,要求线上库的 MySQL 实例都设置 sql_safe_updates=1 来避免没有索引的 update.delete. 结果有一天开发发现下面的一个SQL 没 ...

  8. php+mysql 内联接 和 子查询

    INNER JOIN(内连接):取得两个表中存在连接匹配关系的记录 $sql="SELECT * FROM subject as a INNER JOIN e_user as b ON a. ...

  9. MySQL锁类型以及子查询锁表问题、解锁

    MySQL中select * for update锁表的范围 MySQL中select * for update锁表的问题 由于InnoDB预设是Row-Level Lock,所以只有「明确」的指定主 ...

  10. MySQL使用存储过程代替子查询

    摘要: 出处:黑洞中的奇点 的博客 http://www.cnblogs.com/kelvin19840813/ 您的支持是对博主最大的鼓励,感谢您的认真阅读.本文版权归作者所有,欢迎转载,但请保留该 ...

随机推荐

  1. ZOJ 2283 Challenge of Wisdom

    题意:在一个n * m的地图里,有p个宝藏,每次只能向横纵坐标增加的方向走,问最少走几次能把宝藏都拿走. 解法:按横坐标排序,纵坐标的一个不下降子序列就是一条合法路径,要求多少条不下降子序列可以覆盖所 ...

  2. How to cancel parallel loops in .NET C# z

    Cancellation token Parallel options CancellationTokenSource cancellationTokenSource = new Cancellati ...

  3. 第一个GTK+程序

    在这一章节中,我们将开始编写第一个GTK+程序. 超级简单的例子 我们要“制造”一个超级简单的GTK+程序.就是显示一个空白的窗口. #include <gtk/gtk.h> int ma ...

  4. STM32学习笔记——FSMC 驱动大容量NAND FLASH [复制链接]

    本文原创于观海听涛,原作者版权所有,转载请注明出处. 近几天开发项目需要用到STM32驱动NAND FLASH,但由于开发板例程以及固件库是用于小页(512B),我要用到的FLASH为1G bit的大 ...

  5. html中a标签中的onclick和href的使用

    1. 链接的 onclick 事件被先执行,其次是 href 属性下的动作(页面跳转,或 javascript 伪链接): 假设链接中同时存在 href 与 onclick,如果想让 href 属性下 ...

  6. 关于T公司的强矩阵架构的思考

    我所在的T公司是强矩阵架构,关于这类公司,应该是不少大公司的主流架构,也就是说一个职员在公司内不仅在项目内有相应的级别,在其行政上也是有相应的级别,日常工作以项目的内容为主,但是同时也是属于行政的一员 ...

  7. HDU-4681 String 枚举+DP

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4681 题意:给A,B,C三个串,求一个最长的串D,满足D是A和B的subsequence,C是D的su ...

  8. 重新学习struts

    这就是所谓的一边工作一边学习. 今天准备把给公司写个管理页面,按照之前的路数,写起来应该挺快,但是不太规范.也就沉下心来学习一下了. 第一个学习的是,之前,在学校,听师兄说过,对页面编码可用inter ...

  9. Android实例-使用自定义字体文件(XE8+小米2)

    结果: 1.需要修改DELPHI自身的FMX.FontGlyphs.Android.pas,复制到程序的根目录下(红色部分为修改过的). 2.字体文件从 C:\Windows\Fonts 直接拷贝到A ...

  10. Oracle-PLSQL Developer使用笔记

    1.新建菜单 command window ---->命令行,执行sql语句 sql window ---->执行sql语句,可导出CSV,TSV,HTML,XML等类型文件 report ...