sql子查询
一、子查询入门:
1、单值子查询:
单值子查询的唯一限制:子查询的返回值必须只有一行记录,而且只能有一列(又被称为标量子查询)。
可以使用在select语句的列表、表达式中,以及where语句中等。
例1:select 1 as f1,2,(select min(fyearpublished) from t_book),(select max(fyearpublished) from t_book) as f4 from dual;
2、列值子查询:
列值子查询可返回一个多行多列的结果集(又称为表子查询)。
可以使用在select语句的from子句中、insert语句、连接、in子句等。
例1:select t_reader.fname,t2.fyearpublished,t2.fname
from t_reader,(select * from t_book where fyearpublished < 1800) t2;
表子查询可以看做一张临时表,所以引用子查询中列的时候必须使用子查询中定义的列名,也就是如果子查询中为列定义了别名,那么在引用的时候也要使用别名。
例2:select t_reader.fname,t2.fyear,t2.fname,t2.f3
from t_reader,(select fyearpublished as fyear,fname,1+2 as f3 from t_book where fyearpublished < 1800) t2;
二、select列表中的标量子查询:
例1:select fid,fname,(select max(fyearpublished) from t_book where t_book.fcategoryid = t_category.fid)
from t_category;
这里的子查询与前面的不同,这个子查询必须依赖于外部查询的字段,也就是可以直接单独直行,而这里的子查询是依赖于外部查询中的t_category.fid这个字段的,是无法单独执行的。
三、where子句中的标量子查询:
例1:select freaderid from t_readerfavorite
where fcategoryid=(
select fid from t_category where fname='story'
);
例2:检索每种类型中最早出版的图书:
select t_category.fid,min(t_book.fyearpublished)
from t_category
inner join t_book on t_category.fid=t_book.fcategoryid
group by t_category.fid;
在上一句的基础上,加上书籍名称:
select t_category.fid,t_book.fyearpublished
from t_category
inner join t_book on t_category.fid=t_book.fcategoryid
where t_book.fyearpublished=
(
select min(t_book.fyearpublished) from t_book where t_book.fcategoryid=t_category.fid
);
首先在两个表内进行自连接,再在where子句中使用子查询来过滤数据。
四、集合运算符与子查询:
1、in运算符:
例:检索出所有图书出版年份内入会的读者信息:
select * from t_reader
where fyearofjoin in
(select fyearpublished from t_book);
2、any和some运算符:
在sql中any和some是同义词,基本用法也相同。any必须和其他比较运算符共同使用,而且必须将比较运算符放在any关键字之前,所比较的值也需要匹配子查询中的任意一个值:
例:any和=运算符共同使用的例子,检索出所有图书出版年份内入会的读者信息。“=any”等价于in
select * from t_reader
where fyearofjoin =any
(select fyearpublished from t_book);
any还可以和大于、小于、大于等于、小于等于等比较运算符共同使用。
例:检索出会员出生之前出版的图书。
select * from t_book
where fyearpublished<any
(select fyearofbirth from t_reader);
注意:any运算符不能和固定的集合相匹配,如:select * from t_book where fyearpublished<any(2001,2003,2005);
3、all运算符:
all运算符要求比较的值需要匹配子查询中的所有值,不能单独使用,同样不能与固定值匹配。
例:检索出所有会员入会之前出版的图书:
select * from t_book
where fyearpublished<all
(select fyearofjoin from t_reader);
注意:如果匹配的集合为空,也就是子查询没有返回任何数据的时候,不论与什么比较运算符搭配使用all的返回值将永远是true。
4、exists运算符:
这个是单目运算符,不与列匹配,也不要求匹配的集合是单列。exists是用来检查每一行是否匹配子查询,可以认为exists就是用来测试子查询结果是否为空的,如果结果集为空则匹配结果为false,否则匹配结果为true。
例:测试是否存在山东省的读者:
select * from t_book where exists
(select * from t_reader where fprovince='ShanDong');
例:检索在1950年以前出版的图书的图书类别:
select * from t_category where exists
(select * from t_book
where t_book.fcategoryid=t_category.fid and t_book.fyearpublished<1950);
五、子查询在其他类型sql语句中的应用:
1、在insert语句中的应用:
例:insert into t_readerfavorite(fcategoryid,freaderid)
//为t_reader表中每一个读者都在t_readerfavorite表中创建一条fcategoryid等于1的记录
select 1,fid from t_reader
where not exists
(select * from t_readerfavorite where t_readerfavorite.fcategoryid=1 and t_readerfavorite.freaderid=t_reader.fid);
2、在update语句中的应用:
例:将所有同类书本数超过3本的图书的出版日期更新为2005:
update t_book b1
set b1.fyearpublished=2005
where(select count(*) from t_book b2 where b1.fcategoryid=b2.fcategoryid)>3;
3、在delete语句中的应用:
例:将所有同类书本数超过3本的图书删除:
delete from t_book b1
where(select count(*) from t_book b2 where b1.fcategoryid=b2.fcategoryid)>3;
sql子查询的更多相关文章
- sql子查询 嵌套SELECT语句
嵌套SELECT语句也叫子查询,一个 SELECT 语句的查询结果能够作为另一个语句的输入值.子查询不但能够出现在Where子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在sele ...
- SQL子查询/嵌套查询
sql子查询 嵌套SELECT语句 嵌套SELECT语句也叫子查询,一个 SELECT 语句的查询结果能够作为另一个语句的输入值.子查询不但能够出现在Where子句中,也能够出现在from子句中,作为 ...
- SQL 子查询,连接查询复习
use lianxi0720 go --创建部门表 create table bumen ( bcode int primary key,--部门编号 bname ), --部门名称 bceo ), ...
- Sql Server的艺术(六) SQL 子查询,创建使用返回多行的子查询,子查询创建视图
子查询或内部查询或嵌套查询在另一个SQL查询的查询和嵌入式WHERE子句中. 子查询用于返回将被用于在主查询作为条件的数据,以进一步限制要检索的数据. 子查询可以在SELECT,INSERT,UPDA ...
- sql子查询在insert、update、delete中的应用
子查询可以应用在INSERT.UPDATE以及DELETE等语句中,合理的使用子查询将能够简化功能的实现并且极大的提高SQL语句执行的效率 用到的表: CREATE TABLE `t_readerfa ...
- SQL 子查询 EXISTS 和 NOT EXISTS
MySQL EXISTS 和 NOT EXISTS 子查询语法如下: SELECT … FROM table WHERE EXISTS (subquery) 该语法可以理解为:将主查询的数据,放到子查 ...
- SQL Server温故系列(3):SQL 子查询 & 公用表表达式 CTE
1.子查询 Subqueries 1.1.单行子查询 1.2.多行子查询 1.3.相关子查询 1.4.嵌套子查询 1.5.子查询小结及性能问题 2.公用表表达式 CTE 2.1.普通公用表表达式 2. ...
- SQL查询优化思维即SQL子查询
一. 什么叫子查询 定义及分类 子查询又称内部查询,而包含子查询的语句称之外部查询(又称主查询).所有的子查询可以分为两类,即相关子查询和非相关子查询. 非相关子查询是独立于外部查询的子查询,子查询总 ...
- PL/SQL 子查询
一.概述 在一个SQL语句中嵌套另一个SQL语句成为子查询.包括单行子查询,多行子查询,多列子查询. 注意,当在DDL语句中引用子查询时,可以带有Order By子句:但是当在where子句.Set子 ...
随机推荐
- crontabs linux定时任务功能安装
crontab命令常见于Unix和Linux的操作系统之中,用于设置周期性被执行的指令.该命令从标准输入设备读取指令,并将其存放于"crontab"文件中,以供之后读取和执行.通常 ...
- CSS开发规范
虽然很久之前整理过一份简单的CSS规范,但是当时写的也不是很全面,有些细节也没有照顾到.记录一份较详细的版本,以备不时之需. 命名规范 [强制] class一律使用小写字母+下划线格式命名 例: cl ...
- 使用Python批量下载ftp服务器中的内容
使用ftplib,轻松实现从ftp服务器上下载所需要的文件,包括目录结构等,支持了一下断点续传 from ftplib import FTP import sys import os import r ...
- 使用performance monitor 查看 每一个cpu core的cpu time
使用performance monitor 查看 每一个cpu core的cpu time: 打开performance monitor,添加 counter 如下 运行一段cpu bound 的代码 ...
- robotframework的学习笔记(十三)------Robot Framework常用库简介
标准库 Robot Framework可以直接导入使用的库,包括: Builtin:包含经常需要的关键字.自动导入无需import,因此总是可用的 Dialogs:提供了暂停测试执行和从用户的输入方式 ...
- Robot Framework学习笔记(六)------RIDE界面说明
RIDE是一款专门用来编辑Robot Framework用例的软件,用Python编写并且开源. 1.测试项目.测试套件Edit 标签 测试项目和测试套件所提供的 Edit 标签的功能是一样的. 在 ...
- 基于web的网上书城系统开发-----需求分析
网上书店管理系统主要针对中小型书店,图书管理员将图书信息整理归类发布到网上.,用户登录该网站后进行浏览图书信息.购买等活动. 前台客户输入的数据交给后台数据库处理并及时反馈给双方.客户和管理者拥有相应 ...
- UWP 手绘视频创作工具技术分享系列 - 全新的 UWP 来画视频
从2017年11月开始,我们开始规划和开发全新的来画Pro,在12月23日的短视频峰会上推出了预览版供参会者体验,得到了很高的评价和关注度.吸取反馈建议后,终于在2018年1月11日正式推出了全新版本 ...
- 【转载】netstat--查看服务器[有效]连接数--统计端口并发数--access.log分析
简介 Netstat 命令用于显示各种网络相关信息,如网络连接,路由表,接口状态 (Interface Statistics),masquerade 连接,多播成员 (Multicast Member ...
- iOS QQ分享图片无反应问题
受iOS 9 上 http 限制 需要在info.plist文件添加必要string <key>LSApplicationQueriesSchemes</key> <ar ...