高级查询的使用

本文介绍了数据库查询中的子查询技术,包括在WHERE子句中使用子查询来查找Java成绩最高学生的详情,以及将子查询结果作为查询的一部分和FROM条件。还讨论了使用RANK函数获取每门课程中最高分的学生信息,并提到了联合查询在数据操作中的作用。
摘要由CSDN通过智能技术生成

子查询

子语句的查询结果作为where 的条件语句(where )

#方法一: 使用where语句
#查询Java成绩最高的学生信息
select  MAX(score) from cla where sconame ='java'
#进行where 语句的嵌套
select * from cla  where  score=(select  MAX(score) from cla where sconame ='java')

子语句的查询结果作为查询语句的一部分(select )

#方法二:子查询的结果做为查询结果的一部分
#根据cen表中的id提取出所对应的name,在根据id插入到good表中
select g.name, g.price ,g.sepc ,g.tags, (select name from cen where cen.id= g.cid ) rr from   good g 

子语句的查询结果集作为from的条件语句(from)

#方法三 子查询的结果集  作为from的子句
#查询每门课程中 成绩排名第一的信息
select * from cla
select RANK() over(PARTITION by  sconame  order by score desc ) r ,c.*  from cla c
#这里为什么不能用In,可以用的
select * from (select RANK() over(PARTITION by  sconame  order by score desc ) r ,c.*  from cla c )  r  where r = 1    where  r between 1 and 2   where r = 1

连接查询

联合查询

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值