二十、视图、序列和同义词
21.1 视图
视图是从一个表或多个表中导出的虚表,它与常规表不同之处在于它并不存储数据—它只是在一个存储的查询中定义。视图同真实表一样,也包含一系列带有名称的列和数据。
视图建立在已有表的基础上,视图赖以建立的这些表称为基表。
向视图提供数据内容的语句为 SELECT 语句,可以将视图理解为存储起来的 SELECT 语句。
视图向用户提供基表数据的另一种表现形式。
21.1.1 视图的分类
视图分为简单视图还有复杂视图。
所谓简单的视图是只引用一个表,并且它只从基础表中检索数据,不允许修改其中的数据;
复杂的视图是引用多个表,视图越复杂、视图内再查询的表达式就越多越复杂。复杂视图又称为连接视图。
21.1.2 创建视图的语法
CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view
[(alias[, alias]...)]
AS subquery
[WITH CHECK OPTION [CONSTRAINT constraint]]
[WITH READ ONLY [CONSTRAINT constraint]];
注意:在创建视图时应先赋予创建视图的权限,create view或create any view权限
//切换到管理员然后赋予权限
SQL> grant create any view to redarmy;
SQL> grant create view to redarmy;
21.1.3 为什么使用视图?
控制数据访问,提供了一种安全机制,通过视图显示数据时,屏蔽用户不应该知道的数据。
简化查询,select语句构造了一个复杂的查询语句,每次使用必须都得调用它,根据复杂查询的语句创建一个试图,来简化查询。
21.1.4 创建视图时在子查询中给列定义别名
SQL> create view usersview as select username name,password pass from users;
//查询视图
SQL> select * from usersview;
//检索视图的定义
SQL> select * from user_views;
21.1.5 复杂视图举例
SQL> create view empdept as (select e.*,d.dname,d.loc from emp e inner join dept d on e.deptno=d.deptno);
//使用CREATE OR REPLACE VIEW 子句修改视图
SQL> create or replace view usersview as(select * from users);
//创建带有函数、groupby子句的视图
SQL> create or replace view gde as ( select deptno,count(*) cou from emp group by deptno);
//创建连接视图,并且带有函数、group by子句和order by 子句
SQL> create view gdeo as select e.deptno,count(*) cou from emp e inner join dept d on e.deptno=d.deptno group by e.deptno order by e.deptno;
//在以上的案例基础上附加having子句
SQL> create view gdeoh as select e.deptno,count(*) cou from emp e inner join dept d on e.deptno=d.deptno group by e.deptno having count(*)>3 order by e.deptno;
分享到:
相关推荐
Oracle数据库系统应用与开发 pdf 格式 数据库基础
oracle 数据库管理与应用系统开发代码/oracle 数据库管理与应用系统开发代码
资源名称:Oracle数据库开发与应用内容简介:《Oracle数据库开发与应用》分为5部分共25章,涵盖了数据库入门、数据查询、数据修改和维护、数据库编程、数据库管理。《Oracle数据库开发与应用》使用的开发环境是...
這是一篇介紹oracle数据库系统应用与开发的基礎文章,特別適合初學者使用
oracle 数据库的应用开发 oracle 数据库的应用开发
由浅入深地介绍了Oracle 10g系统的使用方法和基本管理。...本书全面介绍使用Oracle数据库管理应用与开发知识,适合作为普通高校计算机专业Oracle教材,也可以作为Oracle数据库开发和应用人员的参考资料。
oracle数据库应用与开发
Oracle 11g中文版数据库管理、应用与开发标准教程
Oracle数据库的应用开发.pptOracle数据库的应用开发.pptOracle数据库的应用开发.pptOracle数据库的应用开发.pptOracle数据库的应用开发.pptOracle数据库的应用开发.pptOracle数据库的应用开发.ppt
体验数据库的应用→认识 Oracle的工作环境、体验Oracle 10g环境中常用工具操作→数据库的创建与管理→数据表的创建与管理→管理视图→SQL编程语言→PL/SQL编程语言→管理PLSQL存储过程与触发器 →管理安全性→数据库...
Oracle 数据库管理与应用系统开发: Oracle编程 创建存储过程 创建自定义类型 使用存储过程和函数 创建存储过程 创建函数 使用触发器和作业 创建触发器 创建序列等 跟踪和调试 创建存储过程 创建...
Oracle10g数据库管理与应用系统开发光盘
Oracle数据库的开发与应用培训
学生成绩管理演示系统是一个用 ASP 实现的简单的网上学生成绩 管理系统。使用 ADO 对象来访问后台数据库,包含学生信息的查询界面,学生 信息的录入、修改、删除界面,学生成绩的录入修改界面。
Oracle数据库系统应用开发课程设计说明书,内含完整DFD图、视图设计、过程函数触发器设计以及主要操纵语句。
教程名称:Oracle数据库应用与开发培训PPT课程目录:【】第一章Oracle概述【】第七章Oracle备份与恢复【】第三章空间管理【】第二章体系结构与安全管理【】第五章OraclePLSQL编程基础【】第八章Oracle优化技术【】第...