关系数据库标准语言SQL(9,10)

目录

连接查询

等值与非等值连接查询

自然连接

自身连接

外连接

多表连接

嵌套查询

带有in谓词的子查询

例子

带有比较运算符的子查询

带有ANY或ALL谓词的子查询


连接查询

等值与非等值连接查询

①当连接运算符为"="称为等值连接,其他运算符称为非等值连接。

【例】查询每个学生及其选修课程的情况。 SELECT Student.*SC. FROM Student,SC WHERE Student.Sno=SC.Sno;

自然连接

自然连接:若在等值连接中把目标列中重复的属性列去掉则为自然连接。

自身连接

一个表与其自己进行连接

外连接

外连接分为:

左外连接:列出左边关系中所有的元组。 LEFT OUT JOIN SC ON

右外连接:列出右边关系中所有的元组。 RIGHT OUT JOIN SC ON

多表连接

连接操作是两个以上的表进行连接。

嵌套查询

【说明】①子查询中不能使用ORDER BY子句。

②层层嵌套方式反映了SQL语言的结构化。

③有些嵌套查询可以用连接运算替代。

④外层查询(父查询)、内层查询(子查询)

【例】 SELECT Sname FROM Student 外层查询/父查询

WHERE Sno IN(SELECT Sno FROM SC内层查询/子查询 WHERE Cno='2);

带有in谓词的子查询

在嵌套查询中,子查询的结果往往是个集合,用IN谓词表示父查询的条件在子查询结果的集合中。

例子

查询选修课程名为"信息系统"的学生学号和姓名

SELECT Sno ,Sname FROM Student WHERE Sno IN(SELECT Sno FROM SC WHERE Cno IN(SELECT Cno FROM Course WHERE Cname=·信息系统));

SELECT Sno,Sname FROM Student.SC.Course WHERE Student.Sno=SC.Sno AND SC.Cno=Course.Cno AND Course.Cname=:'信息系统':

带有比较运算符的子查询

当能确切知道内层查询返回单值时,可用比较运算符(>,<,=,>=,<=,!=或<>)

带有ANY或ALL谓词的子查询

ANY任意一个值

ALL所有值

用聚集函数实现子查询要比直接用ANY、ALL效率更高

相关推荐
superman超哥15 分钟前
04 深入 Oracle 并发世界:MVCC、锁、闩锁、事务隔离与并发性能优化的探索
数据库·oracle·性能优化·dba
engchina1 小时前
Neo4j 和 Python 初学者指南:如何使用可选关系匹配优化 Cypher 查询
数据库·python·neo4j
engchina1 小时前
使用 Cypher 查询语言在 Neo4j 中查找最短路径
数据库·neo4j
尘浮生1 小时前
Java项目实战II基于Spring Boot的光影视频平台(开发文档+数据库+源码)
java·开发语言·数据库·spring boot·后端·maven·intellij-idea
威哥爱编程1 小时前
SQL Server 数据太多如何优化
数据库·sql·sqlserver
小华同学ai1 小时前
AJ-Report:一款开源且非常强大的数据可视化大屏和报表工具
数据库·信息可视化·开源
Acrelhuang2 小时前
安科瑞5G基站直流叠光监控系统-安科瑞黄安南
大数据·数据库·数据仓库·物联网
Mephisto.java2 小时前
【大数据学习 | kafka高级部分】kafka的kraft集群
大数据·sql·oracle·kafka·json·hbase
Mephisto.java2 小时前
【大数据学习 | kafka高级部分】kafka的文件存储原理
大数据·sql·oracle·kafka·json
十叶知秋2 小时前
【jmeter】jmeter的线程组功能的详细介绍
数据库·jmeter·性能测试