SQL Server2019数据库之简单子查询的具有方法


Posted in SQL Server onApril 27, 2021

子查询可以完成 SQL 查询中比较复杂的情况,本章主要介绍一些子查询的简单用法。

一、简单子查询

1、简单子查询

子查询是 SELECT 语句内的另外一条 SELECT 语句。通常,语句内可以出现表达式的地方都可以使用子查询。另外,子查询可以从任何表中提取数据,只要对该表有适当的访问权限即可。因此,通过在一个查询内或者在另一个子查询内嵌套子查询,可以从两个或多个表中组合信息而不必编写复杂的整个组合表,然后再过滤掉多余的或不相关的联合行的JOIN语句。

子查询的语法与普通的 SELECT 查询的语法相同,子查询可以包含联合、WHERE 子句、HAVING 子句和 GROUP BY子句。

1.1 子查询的语法

子查询的语法如下:

(SELECT [ALL | DISTINCT]<select item list>
FROM <table list>
[WHERE<search condition>]
[GROUP BY <group item list>
[HAVING <group by search condition>]])

语法规则:

  • 子查询的 SELECT 查询必须使用圆括号括起来。
  • 不能包括 COMPUTE 或 FOR BROWSE 子句。
  • 如果同时指定 TOP 子句,则可能只包括 ORDER BY 子句。
  • 子查询最多可以嵌套 32 层。
  • 任何可以使用表达式的地方都可以使用子查询,只要它返回的是单个值。
  • 如果某个表只出现在子查询中而不出现在外部查询中,那么该表中的列就无法包含在输出中。

1.2 子查询常用的语法格式

(1) 第一种语法格式

WHERE 查询表达式 [NOT] IN(子查询)

(2) 第二种语法格式

WHERE 查询表达式 比较运算符 [ANY|ALL](子查询)

(3) 第三种语法格式

WHERE [NOT] EXISTS(子查询)

1.3 子查询与其他 SELECT语句之间的区别

子查询除了必须在括号中出现以外,与其他 SELECT 语句之间还有以下几点不同。

  • SELECT 语句只能使用那些来自 FROM 子句中的表中的列,子查询不仅可以使用在该子查询的 FROM 子句中的表,而且还可以使用子查询的 FROM 子句中表的任何列。
  • SELECT 语句中的子查询必须返回单一数据列。另外,根据其在查询中的使用方法(如将子查询结果用作包括子查询的 SELECT 子句中的一个数据项),包括子查询的查询可能要求子查询返回单个值(而不是来自单列的多个值)。
  • 子查询不能有 ORDER BY 子句(因为用户看不到返回多个数据值的子查询的结果表,所以对隐藏的中间结果表排序就没有什么意义)。
  • 子查询必须由一个 SELECT 语句组成,也就是不能将多个 SQL 语句用 UNION 组合起来作为一个子查询。

2、SELECT 列表中的子查询

子查询是 SELECT 查询内的返回一个值的表达式,就像返回值中的单个列一样。但是,在一个表达式中,子查询必须只返回一条记录,这样的子查询被称为标量子查询(scalar subquery),也必须被封闭在圆括号内。

【例1】根据图书的作者,获取不同作者编写的图书中价格最高的信息。SQL 语句如下:

SELECT tb_book_author,tb_author_department,
(SELECT MAX(book_price) FROM tb_book 
WHERE tb_book_author.tb_book_author = tb_book.tb_book_author) AS 价格
FROM tb_book_author;

查询结果如下图所示:

SQL Server2019数据库之简单子查询的具有方法

3、比较子查询

在 WHERE 子句中可以使用单行比较运算符来比较某个表达式与子查询的结果,可以使用的比较运算符包括:=、>、>=、<、<=、<>(或!=)等。这些比较运算符都可以连接一个子查询,且在使用 ALL 或者 ANY 修饰的比较运算符连接子查询时,必须保证子查询所返回的结果集合中只有单行数据,否则将引起查询错误。

【例2】应用比较运算符 >,查询商品信息表 goods 中 cat_id 的值大于品牌表 brand 中品牌名称为 蓝月亮 的商品信息。SQL 语句如下:

SELECT cat_id, goods_name
FROM goods
WHERE cat_id>(SELECT cat_id FROM brand WHERE name='蓝月亮');

查询结果如下图所示:

SQL Server2019数据库之简单子查询的具有方法

由于子查询只能返回一个值,因此,如果子查询的结果不是返回单个值,那么系统就会发出错误信息。

SELECT cat_id, goods_name
FROM goods
WHERE cat_id>(SELECT * FROM brand WHERE name='蓝月亮');

执行该 SQL 语句,如下图所示:

SQL Server2019数据库之简单子查询的具有方法

子查询中不能包含 ORDER BY 子句,看下面的 SQL 语句:

SELECT cat_id, goods_name
FROM goods
WHERE cat_id>(SELECT cat_id FROM brand WHERE name='蓝月亮' ORDER BY cat_id);

执行该 SQL 语句,如下图所示:

SQL Server2019数据库之简单子查询的具有方法

4、子查询中使用聚合函数

聚合函数 SUM()、COUNT()、MAX()、MIN() 和 AVG() 都返回单个值。在子查询中应用聚合函数,并将该函数返回的结果应用到 WHERE 子句的查询条件中。

【例3】应用聚合函数 AVG(求 emp 员工表中员工的平均工资,并将结果作为 WHERE 子句的查询条件,通过 SQL 语句获取工资大于平均工资的员工信息。SQL 语句如下:

SELECT ename, sal, job
FROM emp
WHERE sal > (SELECT AVG(sal) FROM emp);

查询结果如下图所示:

SQL Server2019数据库之简单子查询的具有方法

小结:本章讲解了子查询的简单用法。子查询是 SELECT 语句内的另外一条 SELECT 语句,也被称为 SQL 查询的嵌套。在实际开发中,一条 SQL 语句中不要嵌套太多子查询,否则会降低系统效率,影响代码的可读性。

到此这篇关于SQL Server2019数据库之简单子查询的具有方法的文章就介绍到这了,更多相关SQL Server2019子查询内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

SQL Server 相关文章推荐
SQL Server数据定义——模式与基本表操作
Apr 05 SQL Server
SQLServer2019 数据库环境搭建与使用的实现
Apr 08 SQL Server
SQLServer 错误: 15404,无法获取有关 Windows NT 组/用户 WIN-8IVSNAQS8T7\Administrator 的信息
Jun 30 SQL Server
SQL Server中使用判断语句(IF ELSE/CASE WHEN )案例
Jul 07 SQL Server
数据库之SQL技巧整理案例
Jul 07 SQL Server
SqlServer数据库远程连接案例教程
Jul 15 SQL Server
利用 SQL Server 过滤索引提高查询语句的性能分析
Jul 15 SQL Server
SQL SERVER实现连接与合并查询
Feb 24 SQL Server
SQL Server数据库基本概念、组成、常用对象与约束
Mar 20 SQL Server
SQL Server远程连接的设置步骤(图文)
Mar 23 SQL Server
SQL Server数据库查询出现阻塞之性能调优
Apr 10 SQL Server
SQL Server删除表中的重复数据
May 25 SQL Server
SQL Server中交叉联接的用法详解
SqlServer 垂直分表(减少程序改动)
Apr 16 #SQL Server
sqlserver2017共享功能目录路径不可改的解决方法
SQLServer2008提示评估期已过解决方案
SQLServer2019 数据库的基本使用之图形化界面操作的实现
SQLServer2019 数据库环境搭建与使用的实现
SQLServer 日期函数大全(小结)
Apr 08 #SQL Server
You might like
php中sql注入漏洞示例 sql注入漏洞修复
2014/01/24 PHP
PHP 将dataurl转成图片image方法总结
2016/10/14 PHP
php设计模式之迭代器模式实例分析【星际争霸游戏案例】
2020/04/07 PHP
通过下拉框的值来确定输入框是否可以为空的代码
2011/10/18 Javascript
Jquery判断$(&quot;#id&quot;)获取的对象是否存在的方法
2013/09/25 Javascript
js验证输入是否为手机号码或电话号码示例
2013/12/30 Javascript
jQuery实现视频作为全屏幕背景
2014/12/18 Javascript
javascript作用域问题实例分析
2015/07/13 Javascript
谷歌Chrome浏览器扩展程序开发小记
2016/01/06 Javascript
jQuery筛选数组之grep、each、inArray、map的用法及遍历json对象
2016/06/20 Javascript
jQuery Easyui使用(二)之可折叠面板动态加载无效果的解决方法
2016/08/17 Javascript
详细讲解JavaScript中的this绑定
2016/10/10 Javascript
微信小程序 传值取值的几种方法总结
2017/01/16 Javascript
vue element-ui 绑定@keyup事件无效的解决方法
2018/03/09 Javascript
解决vue自定义全局消息框组件问题
2019/11/22 Javascript
es6函数name属性功能与用法实例分析
2020/04/18 Javascript
删除目录下相同文件的python代码(逐级优化)
2012/05/25 Python
Python开发SQLite3数据库相关操作详解【连接,查询,插入,更新,删除,关闭等】
2017/07/27 Python
Django框架模板介绍
2019/01/15 Python
20行python代码的入门级小游戏的详解
2019/05/05 Python
python正则-re的用法详解
2019/07/28 Python
python列表推导式操作解析
2019/11/26 Python
Python sep参数使用方法详解
2020/02/12 Python
python3 logging日志封装实例
2020/04/08 Python
手把手教你从PyCharm安装到激活(最新激活码),亲测有效可激活至2089年
2020/11/25 Python
用python对oracle进行简单性能测试
2020/12/05 Python
如何用Lucene索引数据库
2016/02/23 面试题
程序集与命名空间有什么不同
2014/07/25 面试题
生产部统计员岗位职责
2014/01/05 职场文书
车祸赔偿收入证明
2014/01/09 职场文书
刚毕业大学生自荐信范文
2014/02/20 职场文书
领导班子四风对照检查材料
2014/09/23 职场文书
业务员岗位职责范本
2015/04/03 职场文书
拾金不昧表扬信怎么写
2015/05/04 职场文书
2015年小学财务工作总结
2015/07/20 职场文书
Goland使用Go Modules创建/管理项目的操作
2021/05/06 Golang