Oracle-子查询

举报
小奇JAVA 发表于 2022/06/28 22:41:50 2022/06/28
【摘要】 工欲善其事必先利其器 文章持续更新,可以微信搜索【小奇JAVA面试】第一时间阅读,回复【资料】获取福利,回复【项目】获取项目源码,回复【简历模板】获取简历模板,回复【学习路线图】获取学习路线图。 ...

工欲善其事必先利其器
文章持续更新,可以微信搜索【小奇JAVA面试】第一时间阅读,回复【资料】获取福利,回复【项目】获取项目源码,回复【简历模板】获取简历模板,回复【学习路线图】获取学习路线图。

在这里插入图片描述


一、子查询

exists():判断,如果子查询有返回数据,那么就执行外部查询

1、查询学生中年龄最小的学生信息

select * from student where age = (select min(age) from student);

  
 
  • 1

2、查询年龄和“张三”一样大的学生信息

select * from student where age = (select age from student where name = '张三')

  
 
  • 1

3、查询年龄,性别和“张三”一样的学生信息,不包括“张三”

select * from student where (age,sex) = (select age,sex from student where name = '张三')
and name <> '张三'

  
 
  • 1
  • 2

4、查询年龄和“张三”或者“李四”相同的学生信息

select * from student where age in (select age from student where name ='张三' or '李四')

  
 
  • 1

5、如果有姓名为“张三”的学生,那么就查询出所有学生信息,如果没有姓名为“张三”的学生,就什么都不查询

select * from student where exists(select * from student where name = '张三')

  
 
  • 1

二、在having中使用子查询

1、查询出班级平均分高于年级平均分的班级、平均分、班级人数

select class,count(*),avg(grade) from student group by class having avg(grade) > (select avg(grade) from student)

  
 
  • 1

三、在from子句中使用子查询

1、查询学生id和老师进行班级分组后的sid相等的学生id

select s.id from student s (select t.id,t.class from teacher t group by t.class) where s.id = t.sid

  
 
  • 1

四、总结

这里的相关内容还没有整理完毕,文章后面持续更新,建议收藏。

文章中涉及到的命令大家一定要像我一样每个都敲几遍,只有在敲的过程中才能发现自己对命令是否真正的掌握了。

可以微信搜索【小奇JAVA面试】第一时间阅读,回复【资料】获取福利,回复【项目】获取项目源码,回复【简历模板】获取简历模板,回复【学习路线图】获取学习路线图。

文章来源: xiaoqijava.blog.csdn.net,作者:旷世奇才李先生,版权归原作者所有,如需转载,请联系作者。

原文链接:xiaoqijava.blog.csdn.net/article/details/125495062

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。