300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > MySQL的子查询中FROM和EXISTS子句的使用教程【MySQL】

MySQL的子查询中FROM和EXISTS子句的使用教程【MySQL】

时间:2021-04-16 02:56:25

相关推荐

MySQL的子查询中FROM和EXISTS子句的使用教程【MySQL】

数据库|mysql教程

MySQL,FROM,EXISTS,教程,MySQL教

数据库-mysql教程

FROM 子查询

FROM 子句中的子查询

MySQL FROM 子查询是指 FROM 的子句作为子查询语句,主查询再到子查询结果中获取需要的数据。FROM 子查询语法如下:

cocos h5 源码,vscode怎么没法运行了,sata安装ubuntu,清理tomcat日志文件,网上爬虫下载,php 静态变量 引用,seo网页描述怎么写推广,资源网 网站源码,discuz 模板 gbk转utf8lzw

SELECT ... FROM (subquery) AS name ...

仿网易云课堂app源码,ubuntu查询gpu数,视频爬虫怎么用,php过滤加号,joo hee seolzw

子查询会生成一个临时表,由于 FROM 子句中的每个表必须有一个名称,因此 AS name 是必须的。FROM 子查询也称为衍生数据表子查询。

FROM 子查询实例

table1:

在线工具页面源码查看器,vscode 调试代码,ubuntu截屏快捷,tomcat控制界面,c sqlite 编码,wordpress 图片插件,web前端的主流框架,爬虫的编写,.php$ 安全,seo 工作内容,企业网站留言板源码,网页左右广告,小米商城前台模板下载,点击页面爱心,用php做文章管理系统,婚恋交友微信公众号的程序源码lzw

s1 s21 52 123 20

FROM 子查询 SQL 如下:

SELECT s1,s2 FROM (SELECT s1, s2*2 AS s2 FROM table1) AS temp WHERE s1 > 1

查询返回结果如下所示:

s1 s22 243 40

提示

MySQL FROM 子句中的子查询可以返回标量、列、行或表,但不能为有关联的子查询。

MySQL 子查询 EXISTS 和 NOT EXISTS

MySQL EXISTS 和 NOT EXISTS 子查询

MySQL EXISTS 和 NOT EXISTS 子查询语法如下:

SELECT ... FROM table WHERE EXISTS (subquery)

该语法可以理解为:将主查询的数据,放到子查询中做条件验证,根据验证结果(TRUE 或 FALSE)来决定主查询的数据结果是否得以保留。

MySQL EXISTS 子查询实例

下面以实际的例子来理解 EXISTS 子查询。下面是原始的数据表:

article 文章表:

user 用户表:

我们要查出 article 表中的数据,但要求 uid 必须在 user 表中存在。SQL 语句如下:

SELECT * FROM article WHERE EXISTS (SELECT * FROM user WHERE article.uid = user.uid)

返回查询结果如下:

从语句执行结果可以看出,article 表中第 4 条记录没有被保留,原因就是该条记录的数据在子查询中返回的结果是 FALSE 。

当上面的 SQL 使用 NOT EXISTS 时,查询的结果就是 article 表中 uid 不存在于 user 表中的数据记录。

提示

EXISTS (subquery) 只返回 TRUE 或 FALSE,因此子查询中的 SELECT * 也可以是 SELECT 1 或其他,官方说法是实际执行时会忽略 SELECT 清单,因此没有区别。

EXISTS 子查询的实际执行过程可能经过了优化而不是我们理解上的逐条对比,如果担忧效率问题,可进行实际检验以确定是否有效率问题。

EXISTS 子查询往往也可以用条件表达式、其他子查询或者 JOIN 来替代,何种最优需要具体问题具体分析。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。