自定义View系列教程00–推翻自己和过往,重学自定义View
自定义View系列教程01–常用工具介绍
自定义View系列教程02–onMeasure源码详尽分析
自定义View系列教程03–onLayout源码详尽分析
自定义View系列教程04–Draw源码分析及其实践
自定义View系列教程05–示例分析
自定义View系列教程06–详解View的Touch事件处理
自定义View系列教程07–详解ViewGroup分发Touch事件
自定义View系列教程08–滑动冲突的产生及其处理
探索Android软键盘的疑难杂症
深入探讨Android异步精髓Handler
详解Android主流框架不可或缺的基石
站在源码的肩膀上全解Scroller工作机制
Android多分辨率适配框架(1)— 核心基础
Android多分辨率适配框架(2)— 原理剖析
Android多分辨率适配框架(3)— 使用指南
Android程序员C语言自学完备手册
讲给Android程序员看的前端系列教程(图文版)
讲给Android程序员看的前端系列教程(视频版)
子查询是指一个查询语句嵌套在另一个查询语句内部的查询;该查询语句可以嵌套在一个 SELECT、SELECT…INTO、INSERT…INTO等语句中。在执行查询时,首先会执行子查询中的语句,再将返回的结果作为外层查询的过滤条件。在子査询中通常可以使用比较运算符和IN、EXISTS、ANY、ALL等关键字。
在开始学习子查询之前,我们先准备好数据,代码如下:
DROP TABLE IF EXISTS student;DROP TABLE IF EXISTS class;-- 创建班级表CREATE TABLE class( cid int (4) NOT NULL PRIMARY KEY, cname varchar(20));-- 创建学生表CREATE TABLE student ( sid int (4) NOT NULL PRIMARY KEY, sname varchar (20), sage int (2), classid int (4) NOT NULL);-- 向班级表插入数据INSERT INTO class VALUES(1001,'Java');INSERT INTO class VALUES(1002,'C++');INSERT INTO class VALUES(1003,'Python');INSERT INTO class VALUES(1004,'PHP');INSERT INTO class VALUES(1005,'Android');-- 向学生表插入数据INSERT INTO student VALUES(1,'刘婷婷',20,1001);INSERT INTO student VALUES(2,'王琴琴',21,1002);INSERT INTO student VALUES(3,'杨洋洋',24,1003);INSERT INTO student VALUES(4,'李霞霞',23,1004);INSERT INTO student VALUES(5,'吴桃桃',21,1001);INSERT INTO student VALUES(6,'高倩倩',26,1001);INSERT INTO student VALUES(7,'甘丽丽',27,1002);
在子查询中可使用>、<、=、>=、<=、!=
等比较运算符。
示例如下:
-- 查询高倩倩同学所在班级的信息SELECT * FROM class WHERE cid=(SELECT classid FROM student WHERE sname='高倩倩');-- 查询比高倩倩同学所在班级编号还大的班级的信息SELECT * FROM class WHERE cid>(SELECT classid FROM student WHERE sname='高倩倩');
结果如下:
使用[NOT] IN关键字进行子查询时内层查询语句仅返回一个数据列,这个数据列中的值供外层查询语句进行比较操作。
示例如下:
-- 查询年纪大小为21的学生的所在班级的信息SELECT * FROM class WHERE cid IN (SELECT classid FROM student WHERE sage=21);
结果如下:
示例如下:
-- 查询年纪大小不为21的学生的所在班级的信息SELECT * FROM class WHERE cid NOT IN (SELECT classid FROM student WHERE sage=21);
结果如下:
EXISTS关键字后面的参数可以是任意一个子查询, 它不产生任何数据只返回TRUE或FALSE。当返回值为TRUE时外层查询才会 执行。
示例如下:
-- 假若高倩倩同学在学生表中则从班级表查询所有班级信息SELECT * FROM class WHERE EXISTS (SELECT * FROM student WHERE sname='高倩倩');
结果如下:
ANY关键字表示满足其中任意一个条件就返回一个结果作为外层查询条件。
示例如下:
-- 查询比任一学生所属班级号还大的班级编号SELECT * FROM class WHERE cid > ANY (SELECT classid FROM student);
结果如下:
ALL关键字与ANY有点类似,只不过带ALL关键字的子査询返回的结果需同时满足所有内层査询条件。
示例如下:
-- 查询比所有学生所属班级号还大的班级编号SELECT * FROM class WHERE cid > ALL (SELECT classid FROM student);
结果如下:
在此总结,查询语句的书写顺序和执行顺序。
查询语句的书写顺序
select ===> from ===> where ===> group by ===> having ===> order by ===> limit
查询语句的执行顺序
from ===> where ===> group by ===> having ===> select ===> order by ===> limit
在此,以附录的形式给出本节教程的源码,如下所示:
DROP TABLE IF EXISTS student;DROP TABLE IF EXISTS class;-- 创建班级表CREATE TABLE class( cid int (4) NOT NULL PRIMARY KEY, cname varchar(20));-- 创建学生表CREATE TABLE student ( sid int (4) NOT NULL PRIMARY KEY, sname varchar (20), sage int (2), classid int (4) NOT NULL);-- 向班级表插入数据INSERT INTO class VALUES(1001,'Java');INSERT INTO class VALUES(1002,'C++');INSERT INTO class VALUES(1003,'Python');INSERT INTO class VALUES(1004,'PHP');INSERT INTO class VALUES(1005,'Android');-- 向学生表插入数据INSERT INTO student VALUES(1,'刘婷婷',20,1001);INSERT INTO student VALUES(2,'王琴琴',21,1002);INSERT INTO student VALUES(3,'杨洋洋',24,1003);INSERT INTO student VALUES(4,'李霞霞',23,1004);INSERT INTO student VALUES(5,'吴桃桃',21,1001);INSERT INTO student VALUES(6,'高倩倩',26,1001);INSERT INTO student VALUES(7,'甘丽丽',27,1002);-- 查询高倩倩同学所在班级的信息SELECT * FROM class WHERE cid=(SELECT classid FROM student WHERE sname='高倩倩');-- 查询比高倩倩同学所在班级编号还大的班级的信息SELECT * FROM class WHERE cid>(SELECT classid FROM student WHERE sname='高倩倩');-- 查询年纪大小为21的学生的所在班级的信息SELECT * FROM class WHERE cid IN (SELECT classid FROM student WHERE sage=21);-- 查询年纪大小不为21的学生的所在班级的信息SELECT * FROM class WHERE cid NOT IN (SELECT classid FROM student WHERE sage=21);-- 假若高倩倩同学在学生表中则从班级表查询所有班级信息SELECT * FROM class WHERE EXISTS (SELECT * FROM student WHERE sname='高倩倩');-- 查询比所有学生所属班级号还大的班级编号SELECT * FROM class WHERE cid > ALL (SELECT classid FROM student);
联系客服