SQL查询进阶:集合操作与视图限制

需积分: 10 0 下载量 113 浏览量 更新于2024-08-14 收藏 656KB PPT 举报
"集合查询是数据库操作的重要组成部分,特别是关系数据库标准语言SQL中,它提供了对数据进行复合查询的能力。本话题将深入探讨如何使用UNION和UNION ALL操作符来合并查询结果,并讨论在Oracle数据库中创建和管理视图的一些特性。 在SQL中,UNION操作符用于合并两个或更多SELECT语句的结果集,但会去除重复的行。例如,查询计算机科学系(Sdept='CS')和年龄小于等于19岁的所有学生,可以使用如下的UNION语句: ```sql SELECT * FROM Student WHERE Sdept = 'CS' UNION SELECT * FROM Student WHERE Sage <= 19; ``` 而UNION ALL则保留所有结果,包括重复的行。如果在特定场景下需要包含重复的记录,UNION ALL会是更合适的选择。 视图(View)是SQL中的一个虚拟表,它是由一个或多个SELECT语句的结果组成的。在Oracle数据库中,创建视图时不指定列名是允许的,但如果有列名冲突(如使用SELECT *),会导致“重复的列名”错误。视图的列名默认与基表的列名相同。然而,当基表结构发生变化,如删除一列,即使视图没有明确列名,也会被视为有错误。 删除Oracle中的视图并不需要CASCADE选项,但删除后如果试图查询该视图,系统会返回“不存在”的错误。依赖于该视图的其他视图在查询时则会收到“无效对象”的提示。在无WITH CHECK OPTION的视图中,同样遵循“只能对属于视图的记录进行删除”的原则。 Oracle严格要求视图定义中的WHERE子句中涉及到的属性必须在SELECT列表中出现。例如,如果视图定义是基于WHERE子句筛选出特定部门(Sdept)的学生,但SELECT语句中未包含这个属性(IS_Student),那么这样的视图将不允许插入数据,因为插入操作需要满足WHERE条件。 集合查询和视图是数据库查询和数据抽象的有力工具。正确理解和使用UNION和UNION ALL,以及在Oracle中创建和维护视图的规则,对于有效管理和查询数据库至关重要。"