sql的嵌套查询_sql子查询嵌套优化

sql的嵌套查询_sql子查询嵌套优化最近在做各类小应用,用到了MYSQL,有时候会用到一些比较复杂的嵌套查询,在研究怎么通过SQL实现这些。假设下面这张表(stu)描述学生的基本信息:idnamegrade1Jim72Tom83Cake9………另外一张表(sco)描述学生的成绩信息:stu_idsubjectscore1

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

最近在做各类小应用,用到了MYSQL,有时候会用到一些比较复杂的嵌套查询,在研究怎么通过SQL实现这些。
假设下面这张表(stu)描述学生的基本信息:

id name grade
1 Jim 7
2 Tom 8
3 Cake 9

另外一张表(sco)描述学生的成绩信息:

stu_id subject score
1 math 78
2 math 83
3 physics 90

现在想查询七年级学生的数学成绩,那么sql语句应该这么写:

select * from stu left join sco on stu.id = sco.stu_id where stu.grade = 7 and sco.subject = "math";

两个表都有过滤条件,博主在实际应用场景下,两个表要复杂得多,而且过滤条件也多,于是在想有没有办法先select出两张表,然后再join。从性能上说,先过滤也有利于后续join的过程。当然,数据库对这些肯定有相应优化。我们还是回归到一个基本问题, 两个子查询怎么样进行join呢?

select * from (select * from stu where grade = 7) s left join (select * from sco where subject = "math") t on s.id = t.stu_id;

注意在上面的例子当中,两个子查询的写法,查询语句括起来,紧跟一个表的临时命名。
再写个复杂的例子,我们知道mysql不支持全外连接,如果要对上面的表进行全外连接,怎么办呢?
思路也简单,先左外连接,再右外连接,最后求并。

select * from (select * from stu where grade = 7) s left join (select * from sco where subject = "math") t on s.id = t.stu_id union select * from (select * from stu where grade = 7) s right join (select * from sco where subject = "math") t on s.id = t.stu_id

单从语句上看起来,有点复杂。事实上,sql功能强大,可以实现许多复杂业务的查询。在实际场景,其实很容易遇到这样的情形。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169409.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月10日 上午9:46
下一篇 2022年8月10日 上午10:00


相关推荐

  • 揭秘AI智能体:20个核心概念带你深入理解AI Agent

    揭秘AI智能体:20个核心概念带你深入理解AI Agent

    2026年3月15日
    2
  • IIS配置HTTPS

    IIS配置HTTPS1 新建网站 选中类型为 https 然后更改 SSL 证书为你配置的 SSL 证书 对于 SSL 证书的配置是这样的点开第二步 然后点击创建自签名证书确定以后点开网站看到有个 SSL 双击进去 再选中要求 SSL 选中此步就是为了防止浏览器认为你的网站不安全阻止网站的访问 到此 证书配置完成然后发现 IIS 无法绑定域名 因为 IIS7 默认不支持 HTTPS 绑定域名 此时需要自己手动去设置首先打开 C Windows s

    2026年3月18日
    2
  • VAP简单解读_vip是什么意思

    VAP简单解读_vip是什么意思https://cloud.tencent.com/developer/article/1693852特点:1.先前市面已有开源方案,并非先例2.kotlin语言3.代码量较小,很快就能理解大致逻辑4.需要使用ffmpeg工具进行动画视频的二次处理基本原理:输入mp4文件->MediaExtractor->音频->AudioTrack->视频->Surface…

    2025年8月10日
    5
  • js判断是否是数字——isNaN()函数

    js判断是否是数字——isNaN()函数isNaN  返回一个Boolean值,指明提供的值是否是保留值NaN(不是数字)。  NaN即NotaNumber  isNaN(numValue)  必选项numvalue参数为要检查是否为NAN的值。  说明  假如值是NaN,那么isNaN函数返回true,否则返回false。使用这个函数的典型情况是检查parseInt

    2022年6月18日
    52
  • 恢复微信撤回的图片(不容root,极其简单)

    恢复微信撤回的图片(不容root,极其简单)女友最近用微信发的一些照片总是让我看一下就给撤回,作为程序员的我,当然不甘示弱,怎可以在我熟悉的领域胡作非为呢?于是上网搜了一下恢复微信撤销图片的方法,网上给出的方法各种各样,需要各种软件,还需要root,不仅晦涩难懂而且极其麻烦,一看都不适合给小白使用,作为程序员的我当然也不愿意这样,于是我就自己琢磨。首先,你要相信这样一个道理,你能看到的东西,一定会存在你手机的某个角落,如图片,声音,视频,

    2022年6月18日
    64
  • OpenClaw快速部署指南:2026年全流程技术解析

    OpenClaw快速部署指南:2026年全流程技术解析

    2026年3月13日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号