Oracle 视图索引

Oracle 视图索引第五章视图索引的操作5.1视图的功能一个视图实际上就是封装了一条复杂的查询语句注:为了在当前用户模式中创建视图,要求数据库用户必须有createanyview(创建任何视图)的权限。5.2创建视图的语法create[orreplace]view视图名称as查询语句例:建立一个视图,包含全部部门编号为20的部门的雇员信息(雇员编号,姓名,工作,部门编号)createview…

大家好,又见面了,我是你们的朋友全栈君。

第五章 视图索引的操作

5.1 视图的功能

一个视图实际上就是封装了一条复杂的查询语句

注:为了在当前用户模式中创建视图,要求数据库用户必须有create any view(创建任何视图)的权限

Oracle 视图索引

5.2 创建视图的语法

create [or replace] view 视图名称 as 查询语句

例:建立一个视图,包含全部部门编号为20的部门的雇员信息(雇员编号,姓名,工作,部门编号)

create view emp_view as select empno,ename,job,deptno

from emp where deptno=20;

试图创建完成之后,就可以像查找表那样直接对视图进行查询的操作

Oracle 视图索引

5.3 查询视图

select * from emp_view;

 Oracle 视图索引

此时,是通过试图找到的20部门的所有数据,也就是发现,可以使用视图包装需要的查询语句。

例:向emp_view视图中插入一条数据

Oracle 视图索引

5.4 更新视图信息

例:修改视图中的9527的部门编号

update emp_view set ename=’西方’ where emono=9527;

 Oracle 视图索引

5.5 删除视图中的信息

delete from 视图名字 [where 条件]

例:删除9527的信息   delete fromemp_view where empno=9527;

 Oracle 视图索引

5.6 建立只读视图

with read only:创建的视图只读

定义只读视图后,数据库用户只能在该视图上执行select语句。

例:创建只能读的视图  

create or replace view VIEW_EMP_READONLY

as select * from dept where deptno!=88 with read only;

 Oracle 视图索引

例:更新视图中所有部门位置为‘长春’的记录(选择非只读视图)

update VIEW_EMP_READONLY set loc=’长春’;

5.7 复杂视图

复杂视图是指包含函数,表达式,分组数据的视图,主要目的是为了简化操作,需要注意的是,当视图的查询包含函数或者表达式的时候,必须定义别名。

例:创建一个视图,要求查询每个部门的工资情况(最高,最低,平均)

create or replace view emp_view_complex

as 

select deptno 部门编号,max(sal) 最高工资,min(sal) 最低工资,avg(sal) 平均工资

from emp

group by deptno;

select * from emp_view_complex group by 部门编号;

Oracle 视图索引

5.8 连接视图

连接视图基于多个表所建立的视图,使用连接视图的主要目的是为了简化连接插叙

注:建立连接视图时,必须使用where子句中指定有效的连接条件

例:创建一个deptemp表相互关联的视图,并要求该视图只能查询部门编号为20的记录信息。

create or replace view emp_view_union

as

select dept.deptno,dname,emp.ename,sal

from dept,emp

where dept.deptno=emp.deptno

and dept.deptno=20;

Oracle 视图索引

5.9 删除视图

格式:drop view 视图名称

例:删除视图emp_view_union   drop view emp_view_union;

Oracle 视图索引

5.10 索引概述

若一个表存在海量的数据记录,当对表执行指定条件查询的时候,常规的查询方法是将所有记录全部读取出来,然后把读取的每条记录与查询条件进行对比,最后返回满足条件的结果。这样进行的操作时间的开销和I/O开销很大,此时,可以考虑通过建立索引来减小系统开销。

若要在表中查询指定的记录,在没有索引的情况下,必须遍历整个表,而有了索引之后,只需要在索引中查询条件的索引字段值,就可以通过保存在索引中的rowid(系统为每个记录分配的物理地址)快速找到表中对应的记录

若将表看成一本书,索引的作用就是目录。在没有目录的情况下,要找到指定的内容就必须阅读全书,有了目录,就能通过目录快速找到知识点。

5.11 创建索引

建立索引的语法:create index语句

注:在创建索引时,要求用户具有create any index系统权限,若无此权限先授权。

Grant create any index to scott;

例:在scott模式下,为emp表的deptno列创建索引。

create index emp_deptno_index on emp(deptno);

Oracle 视图索引

复合索引基于两个列或多个列的索引在同一张表上可以有多个索引,但是要求列的组合必须不同。如:

create index emp_idx1 on emp(ename,job);

create index emp_idx2 on emp(job,ename);

 Oracle 视图索引

Oracle 视图索引

5.12 删除索引

格式:drop index 索引名称

注:需要有drop any index权限

例:删除索引emp_deptno_index    drop index emp_deptno_index;

 Oracle 视图索引

5.13 索引有一些先天不足

1.系统需占用大约为表1.2倍的硬盘和内存空间来保存索引。(占用内存空间

2.更新数据时,系统需有额外的时间来同时对索引进行更新,维持数据和索引的一致性。(除了查询操作,其他都慢

因此,不恰当的索引不但于事无补,反而会降低系统性能。因为大量的索引在进行插入,修改和删除操作时比没有索引花费更多的系统时间。

修改用户的密码:alter user 用户名 identified by 密码;

例:将scott的用户密码修改为hello    alter user scott identified by hello; 

Oracle 视图索引
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163022.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 5g的控制信道编码方式_5gnr上行支持的信道编码

    5g的控制信道编码方式_5gnr上行支持的信道编码第1章物理层架构1.1物理层内部功能协议栈1.2物理层编码与处理过程(1)信道编码(2)调制解调(3)层映射(4)扩频预编码(仅仅用于上行,可选)(5)多天线技术的预编码(6)资源映射(7)OFDM变换本文主要探讨NR的信道编码技术第2章NR的物理层信道编码技术概述物理层信道编码不是单一的编码,而是有一组编码组成。以发送为例,阐述物理层信道编码的过程以及其中涉及到的主要,接收过程与之相反。(1)TrBloc……

    2025年7月3日
    2
  • MQTT服务器搭建 windows[通俗易懂]

    MQTT服务器搭建 windows[通俗易懂]typora-copy-images-to:upload软件简介MQ遥测传输(MQTT)是轻量级基于代理的发布/订阅的消息传输协议,设计思想是开放、简单、轻量、易于实现。这些特点使它适用于受限环境。例如,但不仅限于此:网络代价昂贵,带宽低、不可靠。在嵌入设备中运行,处理器和内存资源有限。该协议的特点有:使用发布/订阅消息模式,提供一对多的消息发布,解除应用程序耦合。对负载内容屏蔽的消息传输。使用TCP/IP提供网络连接。有三种消息发布服务质量:“至多一次”,消息发布.

    2022年4月29日
    51
  • pycharm哪个版本_pycharm版本选择

    pycharm哪个版本_pycharm版本选择Pycharm各大版本Pycharm作为python最常见的IDE,常见的有三种版本专业版:功能强大,适合开发者,需要通过付费或学生认证才能使用社区版:可以供广大python爱好者免费使用,具备常用的python库,可以实现基本的python用法,用于试验在工作中出现的错误教育版:基于社区版发展而来,也是免费使用,其功能与社区版相似,但是更适合学生,新人学习,由教师可以创建工程、教学…

    2022年8月28日
    2
  • c#与WMI使用技巧集http://www.cnblogs.com/Sandheart/articles/1568636.html[通俗易懂]

    c#与WMI使用技巧集http://www.cnblogs.com/Sandheart/articles/1568636.html[通俗易懂](转)c#与WMI使用技巧集1、什么是WMI WMI是英文WindowsManagementInstrumentation的简写,它的功能主要是:访问本地主机的一些信息和服务,可以管理远程计算机(当然你必须要拥有足够的权限),比如:重启,关机,关闭进程,创建进程等。 2、如何用WMI获得本地磁盘的信息? 首先要在VS.NET中创建一个项目,然后在添加引用中引用一个.

    2022年9月28日
    3
  • hexo latex 换行 多行公式 终极解决方案

    hexo latex 换行 多行公式 终极解决方案hexo的LaTeX可算把我给折腾死了。。。问题:多行公式无法显示(hexo-renderer-marked,mathjax)看到网上说是因为渲染引擎把\\渲染成\,然后才交给mathjax渲染公式都说把hexo-renderer-marked换成hexo-renderer-kramed,然后再node_modules/kramed/lib/rules/inline.js里修改escape项,照做了,确实解决了问题,但是却出现了新的问题:复杂公式显示错乱,遂放弃。又看到在node_modules/m

    2022年5月14日
    49
  • Mac系统Unity3D中的快捷键

    Mac系统Unity3D中的快捷键command+N新建场景command+O打开场景command+S保存场景Shift+command+S场景另存为Shift+command+B编译设置command+B编译并运行command+zUndo撤销shift+command+zRedo撤销command+XCut剪切command

    2022年5月22日
    60

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号