MySQL(18):Select- subquery子查询
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子查询的更多相关文章
- mysql update不支持子查询更新
先看示例: SELECT uin,account,password,create_user_uin_tree FROM sys_user 结果: 表中的create_user_uin_tree标识该条 ...
- SELECT使用子查询
SELECT使用子查询 SELECT使用子查询,该子查询会执行多次, 次数是由记录数量决定.效率比较低,不推荐使用. //查询部门编号,工资大于等于2000的人数, //工资小于2000的人 ...
- subquery 子查询
#encoding: utf-8 from sqlalchemy import create_engine,Column,Integer,String,Float,func,and_,or_,Enum ...
- MySQL(八)子查询和分组查询
一.子查询 1.子查询(subquery):嵌套在其他查询中的查询. 例如:select user_id from usertable where mobile_no in (select mobil ...
- Mysql - 性能优化之子查询
记得在做项目的时候, 听到过一句话, 尽量不要使用子查询, 那么这一篇就来看一下, 这句话是否是正确的. 那在这之前, 需要介绍一些概念性东西和mysql对语句的大致处理. 当Mysql Server ...
- MySQL 使用JOIN优化子查询
1.数据准备 mysql> select * from student; +----+--------+----------+---------+-------------+ | id | na ...
- mysql sql_safe_updates 不支持子查询的更新。
考虑到开发人员有时候不小心误更新数据,要求线上库的 MySQL 实例都设置 sql_safe_updates=1 来避免没有索引的 update.delete. 结果有一天开发发现下面的一个SQL 没 ...
- php+mysql 内联接 和 子查询
INNER JOIN(内连接):取得两个表中存在连接匹配关系的记录 $sql="SELECT * FROM subject as a INNER JOIN e_user as b ON a. ...
- MySQL锁类型以及子查询锁表问题、解锁
MySQL中select * for update锁表的范围 MySQL中select * for update锁表的问题 由于InnoDB预设是Row-Level Lock,所以只有「明确」的指定主 ...
- MySQL使用存储过程代替子查询
摘要: 出处:黑洞中的奇点 的博客 http://www.cnblogs.com/kelvin19840813/ 您的支持是对博主最大的鼓励,感谢您的认真阅读.本文版权归作者所有,欢迎转载,但请保留该 ...
随机推荐
- Android学习系列(23)--App主界面实现
在上篇文章<Android学习系列(22)--App主界面比较>中我们浅略的分析了几个主界面布局,选了一个最大众化的经典布局.今天我们就这个经典布局,用代码具体的实现它. 1.预览图先看下 ...
- 内存映射 madvise mmap
http://linux.die.net/man/2/madvise mmap && madvise的配合使用 mmap和madvise一起使用例子 mmap的作用是将硬盘文件的内容映 ...
- Spring 教程(一)
一.Spring是什么 通常说的Spring其实指的是Spring Framework,它是Spring下的一个子项目,Spring围绕Spring Framework这个核心项目开发了大量其他项目, ...
- java 实现死锁
package 线程安全的讨论; class DThread implements Runnable { private Object o1=null; private Object o2=null; ...
- uva 12304
题意:要求解答6个关于圆的问题. 1.给出三角形坐标求外接圆 2.给出三角形坐标求内切圆 3.给出一个圆心和半径已知的圆,求过点(x,y)的所有和这个圆相切的直线 4.求所有和已知直线相切的过定点(x ...
- uva 2218 Triathlon
题意:铁人三项赛,给定每个选手游泳,自行车,赛跑三个阶段的平均速度,不知道每段比赛的路程,询问当前这个选手能否胜利. 思路:把题意转化为一个不等式,设比赛长度是1,如果i要战胜j,x.y分别是第一阶段 ...
- windows串口通信的一个活动图
1,打开串口的活动图: 2,关闭串口的活动图:
- 关于mac 80端口问题
使用 maven启动 jettry时 ,jetty使用的是80端口 ,但是 mac 在1024以下的端口似乎是不让随便使用的. 在网上查了好多方式,其中的一种说是做端口转发,其实也就是把80转换成别的 ...
- notepad 如何同时选中同一列的数据 Alt
有时会经常遇到这种情况, 我们要选中数据中的某一列,这个在记事本中是实现不了的,不过我们可以用更高级一点的编辑器. 使用notepad可以帮助我们解决这个问题哦! 操作方法就是 按下ALT键 然后再去 ...
- A Tour of Go Interfaces
An interface type is defined by a set of methods. A value of interface type can hold any value that ...