SQL笔记(14)_第十四章 使用子查询定义未确定数据

本文主要是介绍SQL笔记(14)_第十四章 使用子查询定义未确定数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第十四章 使用子查询定义未确定数据

子查询也叫嵌套查询,是位于另一个查询的WHERE子句里的查询,它返回的数据通常在主查询里作为一个条件,从而进一步限制数据库返回的数据。它可以用于SELECT,UPDATE, DELETE, INSERT语句。

在某些情况下,子查询能够间接的基于一个或多个条件把多个表里的数据关联起来,从而代替结合操作。当使用子查询时,子查询首先被执行,然后主查询再根据其返回的结果继续执行。子查询的结果用于在主查询的WHERE子句里处理表达式。子查询可以用于主查询的WHERE子句或HAVING子句。

标准查询的规则同样也适用于子查询。

子查询必须遵循以下规则:

子查询必须位于圆括号里。

除非主查询里有多个字段让子查询进行比较,否则子查询的SELECT子句里只能有一个字段。

子查询里不能使用ORDER BY子句。在子查询里,我们可以利用GROUP BY子句实现ORDER BY子句的功能。

返回多条记录的子查询只能与多值操作符(比如IN)配合使用。

SELECT列表里不能引用任何BLOB,ARRAY,CLOB,NCLOB类型的值。

子查询不能直接被包围在函数里。

操作符BETWEEN不能用于子查询(外部),但子查询内部可以使用它。

子查询与SELECT语句

虽然子查询可以用于数据操作语句,但它最主要还是用于SELECT语句里,获取数据给主查询使用。

子查询与INSERT语句

INSERT INTO TABLE_NAME [ ( COLUMN1, [ COLUMN2 ] ) ]
SELECT [ * | COLUMN1 | [ COLUMN2 ]]
FROM TABLE1 [, TABLE2]
[ WHERE VALUE OPERATE ]

子查询与UPDATE语句

UPDATE TABLE ...

SET ...= (SELECT ...) 注意返回多个结果的时候用IN而不是用“=”

子查询与DELETE语句

DELETE FROM TABLE_NAME

WHERE ...(SELECT ...)

嵌套子查询

子查询由内向外执行。

关联子查询

关联子查询在很多SQL实现里都存在,它的概念属于ANSI标准。关联子查询时依赖主查询里的信息的子查询,这以为着子查询里的表可以与主查询里的相关联。

子查询的效率

*适当使用关联子查询:在进行关联子查询时,如果要在子查询中使用某个表,必须首先在主查询中引用这个表。


这篇关于SQL笔记(14)_第十四章 使用子查询定义未确定数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/906174

相关文章

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

MySQL主从同步延迟问题的全面解决方案

《MySQL主从同步延迟问题的全面解决方案》MySQL主从同步延迟是分布式数据库系统中的常见问题,会导致从库读取到过期数据,影响业务一致性,下面我将深入分析延迟原因并提供多层次的解决方案,需要的朋友可... 目录一、同步延迟原因深度分析1.1 主从复制原理回顾1.2 延迟产生的关键环节二、实时监控与诊断方案

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

MySQL数据库约束深入详解

《MySQL数据库约束深入详解》:本文主要介绍MySQL数据库约束,在MySQL数据库中,约束是用来限制进入表中的数据类型的一种技术,通过使用约束,可以确保数据的准确性、完整性和可靠性,需要的朋友... 目录一、数据库约束的概念二、约束类型三、NOT NULL 非空约束四、DEFAULT 默认值约束五、UN

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设