oracle其他数据对象 --- 视图

一 介绍:

1.什么是视图:

视图是从一个表或多个表中导出的虚表,它与常规表不同之处在于它并不存储数据,它只是在一个存储的查询中定义.视图同真实表一样,也包含一系列带有名称的列和数据。

注:

(1)视图建立在已有表的基础上, 视图赖以建立的这些表称为基表。

(2)向视图提供数据内容的语句为 SELECT 语句, 可以将视图理解为存储起来的 SELECT 语句.

(3)视图向用户提供基表数据的另一种表现形式

2.视图的优点:

(1)限制数据访问

(2)简化复杂查询

(3)提供数据的相互独立

(4)同样的数据,可以有不同的显示方式

3.缺点:

视图不能提高性能。

4.简单视图和复杂视图

视图只用于查询,对查询数据的封装,通过视图形成一个接口来封装sql语句,供他人访问,视图是一种虚表,视图建立在已有表的基础上,视图依赖以建立的这些表称为基表

向视图提供数据内容 的语句为select语句,可以将视图理解为存储起来的select语句

视图向用户提供基表数据的另一种表现形式

简单的视图:

所谓简单的视图是只引用一个表,并且它只从基础表中检索数据,不允许修改其中的数据;

复杂的视图:

复杂的视图是引用多个表,视图越复杂、视图内再查询的表达式就越多越复杂.

5.基于一个表的简单视图

SQL> create view empSal as select * from emp where sal>=3000;

视图已创建。

注:(1)empSql是创建视图的名字 as之后的是查询的条件

视图自动提交

6.复杂视图

(1)有group by的为复杂的视图

SQL>create view groupView as select deptno,avg(nvl(sal,0)) as avgSal from emp group by deptno;

注:avg(nvl(sal,0))必须使用列别名命名此表达式,也可以这么写:

SQL>create view groupView(deptno,avgSal) as select deptno,avg(nvl(sal,0)) from emp group by deptno;

(2)有多个表的复杂视图创建

SQL> create view groupView1 as (select dname,e.* from (select deptno,avg(nvl(sal,0)) from emp group by deptno) e inner join dept d on d.deptno=e.deptno);

7.修改视图

修改视图用or replace,如:

SQL> create or replace view groupView as (select dname,e.* from (select deptno,avg(nvl(sal,0)) from emp group by deptno) e inner join dept d on d.deptno=e.deptno);

8.为查出的字段起别名

SQL> create or replace view empSal(sename,ssal) as select ename,sal from emp where sal>=3000;

或者可以写为:

SQL> create or replace view empSal as select ename rname,sal salry from emp where sal>=3000;

注:

起别名的时候可以直接在视图的名字后面写上别名,而不在后面查询最大、最小起别名,如:

SQL> create view groupDep(min,max,avg) as  select min(sal),max(sal),avg(sal) from emp group by deptno;

9.删除视图

drop view grouped;

注:删除视图只能删除视图的定义,并不会删除基表的数据

10.视图中使用DML的规定

1. 可以在简单视图中执行 DML 操作

当视图定义中包含以下元素之一时不能使用delete:

(1)组函数

(2)GROUP BY 子句

(3)DISTINCT 关键字

(4)ROWNUM 伪列

2. 当视图定义中包含以下元素之一时不能使用update :

(1)组函数

(2)   GROUP BY子句

(3)   DISTINCT 关键字

(4)   ROWNUM 伪列

(5)列的定义为表达式

3. 当视图定义中包含以下元素之一时不能使用insert :

(1)   组函数

(2)   GROUP BY子句

(3)   DISTINCT 关键字

(4)ROWNUM 伪列

(5)列的定义为表达式

(6)表中非空的列在视图定义中未包括

从以上的规定中可以看出,视图主要是用来查询语句的,而对DML一般情况下不使用视图

11.屏蔽DML操作,使用with read only

SQL> create or replace view empSal(eename,eesal) as select ename,sal from emp where sal>=3000 with read only;

oracle其他数据对象 --- 视图(10级学员 韩晓爽课堂总结)相关推荐

  1. Android数据存储与访问(10级学员张晓丛)

    一.     数据存储与访问 Android为数据存数提供了多种方式: 1>  文件 2>  SharedPreferences 3>  SQLite数据库 4>  内容提供者 ...

  2. Oracl中PL/SQL编程(10级学员 张帅鹏课堂总结)

    Oracl中PL/SQL编程 概述: PL/SQL是oracle的专用语言,它对标准的SQL语言的扩展.SQL语句可以嵌套在PL/SQL语言中,并结合处理语句.举例,一般在银行系统中,都是事先写好的s ...

  3. oracle中部门工资降序排列,oracle面试题整理二(10级学员 乔宇整理)

    Oracle面试题整理二(10级学员 乔宇整理) 1.查询工资最高的3 名员工信息 select * from (select * from emp order by sal desc) where ...

  4. 简述oracle的主要数据库对象,Oracle数据库数据对象分析

    Oracle数据库数据对象分析 Oracle数据库数据对象中最基本的是表和视图,其他还有约束.序列.函数.存储过程.包.触发器等.对数据库的操作可以基本归结为对数据对象的操作,理解和掌握Oracle数 ...

  5. Oracle数据库之对象视图、索引、序列、同义词

    Oracle数据库总结: Oracle数据库之集合运算 Oracle数据库之数据处理 Oracle数据库之建表和管理表 Oracle数据库之对象视图.索引.序列.同义词 视图: 语法: create ...

  6. Oracle之数据对象(同义词、序列、视图、表空间、索引)

    文章目录 数据库对象 概述 同义词 序列 视图 表空间 创建表空间 扩容表空间 增加数据文件 表空间的备份(冷备份) 索引 SQL优化建议(14则) 工具:sql developer 数据库对象 概述 ...

  7. ORCL数据字典(10级学员 张家玮整理)

    ORCL数据字典 ORACLE数据字典是ORACLE数据库的重要组成部分,它提供了诸如数据库结构.数据库对象空间分配和数据库用户等等有关数据库的信息.本文试图从数据库管理系统的若干基本概念出发,具体介 ...

  8. oracle 视图使用rownum,Oracle数据对象--视图

    1.为什么使用视图(1)限制数据的存取:用户只能看到基表的部分信息. (2)使得复杂的查询变得容易:视图中的数据可能来自多个表. (3)使得数据相对比较独立:从项目开发的角度,模块对应视图,模块包含多 ...

  9. Oracle其它数据库对象:视图、序列、同义词

    SQL> --视图: 由一个或者多个表组成的逻辑表 SQL> -创建一个视图,包含了10,20的员工信息 SQL> --创建一个视图,包含了10,20的员工信息 SQL> ed ...

  10. jQuery插件autoComplete介绍(10级学员 张帅鹏总结)

    jQuery插件autoComplete介绍 概述:AutoComplete为自动填充,展示之意.用户在使用文本框搜索信息时,使用插件的autoplete方法绑定文本框.当在文本框中输入某个字符时,通 ...

最新文章

  1. 简单html图片轮播_web前端入门到实战:简单的图片轮播
  2. Protobuf3语言指南
  3. 条款15: 让operator=返回*this的引用
  4. grep -v XXXXX
  5. 允许多域名跨域 php,php后端控制可跨域的域名,允许图片跨域上传
  6. java设计模式之状态模式_Java中的状态设计模式
  7. 成功在MP4封装的H264视频中提取能播放的裸流
  8. 油田生产中的几个“三”
  9. 【平面设计基础】01:抠图—薄、透、露的朦胧美
  10. 智慧校园的关键技术:云计算+物联网+大数据
  11. stuiod3t-2019030.dmg下载及studio3t macOS Cracking教程
  12. 2008网站服务器配置,08CMS网站Windows_2008服务器环境配置方法
  13. 手机号注册获取随机验证码
  14. 苹果笔记本macbook pro如何安装python_Mac OS系统下的安装
  15. 宽带连接720错误代码解决办法
  16. epub转换mobi
  17. 守护安全|AIRIOT城市天然气综合管理解决方案
  18. 计算机病毒装逼桌面,3个Win10神秘装逼小技巧
  19. linux开机启动出现grup,开机出现grub解决方法
  20. ThinkPad T440s 改 T450s

热门文章

  1. 深入理解CSS动画animation
  2. java flex 聊天_【转帖】实现了视频私聊功能
  3. 光量子计算机技术突破,真正突破光刻机封锁的技术诞生了!可编程光量子计算芯片是什么?...
  4. Redis数据结构-字符串对象(SDS)
  5. Joint Autoregressive and Hierarchical Priors for Learned Image Compression文献复现
  6. 读书笔记-人际网络的中心
  7. Ubuntu下交叉编译Qt库并移植至ARM板上
  8. XML与XSD两兄弟
  9. 一个生信人的自白:从生物转生信,我的学习与工作经历
  10. input内加小图标