oracle 创建索引和视图
一: 创建索引有两种方式:
1. 自动添加(oracle 会为主键和唯一约束自动添加索引)
自动创建的索引是无法手动删除的,但是当删除主键约束,唯一约束时,对应的索引也会自动删除;
2. 手动添加
在查询时,经常被用作查询条件的字段应该被添加索引;
添加索引: CREATE INDEX ENAME_INDEX ON EMP (ENAME);
删除索引: DROP INDEX ENAME_INDEX;
二: 添加约束:
ALTER TABLE EMP ADD CONSTRANTS ENAME_UNI UNIQUE (ENAME);
删除约束:
ALTER TABLE EMP DROP CONSTRANTS ENAME_UNI;
观察查询处理结果需要启动追踪器进行浏览:
切换sys账户: conn sys/change_on_install as sysdba;
打开追踪器:set autotrace on;
默认情况下数据执行时采用全表扫描(逐行扫描),如果这样的查询采用全表扫描,如果数据量大的话执行速度一定是很慢的。如果有10000条数据,前5000条数据执行红包含满足条件的内容,后面的逐行扫描查询就是浪费时间
解决问题:唯一可行的办法就是排序,那么对于在数据库里对于不查询的数据的排序,那么就是将其形成一棵树,这棵树的排列形式如下:取第一个数据作为根节点,而后比根节点小的数据放在左边,比根节点打的数据放在右边
数据库之中对于索引的创建有两种形式:
1.当数据列上使用了主键约束或唯一约束的时候自动创建索引;
2.自己手工明确设置一个查询字段,手工创建索引;
例: create index scott.emp_sal_ind on scott.emp(sal);
注:索引并不能100%提高查询性能,索引实现的关键在于整个数据库之中索引树的维护,如果没有了这棵树,索引将无法使用,但是这颗树采用的是制定的索引字段才转换的树,但是如果字段上的内容频繁修改,那么久表示将有大量的内存和性能浪费在了这棵树的维护上,反而造成性能上的下降,所以建立索引的字段也要根据实际的情况有所调整
三: 创建视图
在实际之中数据表的查询都是比较复杂的,在一些传统的技术开发里面,视图的数量往往查过数据表的数量,但随着现在的一些开发(很难找到所谓的专业的数据库开发人员了),这样一来所有编写复杂查询的任务又回到程序员身上了,所以很多程序员为了代码的修改方便,都不再使用视图了。
1.视图是存储在数据字典的一条select语句。通过创建视图可以提取数据的逻辑上的的集合和组合。
视图分为:简单视图和复杂视图
简单视图:只从单表中获取数据、不包含函数和数据组、可实现DML操作
复杂视图:从多表中获取数据、包含函数和数据组、不能实现DML操作
视图创建语句
CREATE[OR REPLACE][FORCE|NOFORCE] VIEW view_name
[(alias[,alias]...)]
AS subquery
[WITH CHECK OPRION[CONSTRAINT constraint]]
[WITH READ ONLY]
其中:
OR REPLACE :若所创建的视图存在,ORACLE自动重建该视图;
FORCE :不关基表是否存在ORACLE都会自动创建该视图;
NOFORCE :只有基表都存在ORACLE才会创建该视图;
alais :为视图产生的列定义的别名;
subquery :一条完整的SELECT语句,可以在该语句中定义别名;
WITH CHECK OPTION :插入或者修改的数据行必须满足视图的定义的约束;
WITH READ ONY :该视图上不能进行任何DML操作;(只读)
例如:
CREATE OR REPLACE VIEW dept_sum_vm
(name,minsal,maxsal,avgsal)
AS SELECT d.dname,min(e.sal),max(e.sal),avg(e.sal)
FROM emp e,dept d
WHERE e.deptno=d.deptno
GROUP BY d.dname;
视图定义原则:
1.视图的查询可以使用复杂的SELECT语法,包括连接/分组查询和子查询;
2.在没有WITH CHECK OPTION和READ ONLY的情况下,查询中不能使用ORDER BY子句
3.如果没有为CHECK OPTION约束命名,系统会自动为之命名,形式为SYS_Cn;
4.OR REPLACE选项可以不删除原视图便可更改其定义并重建,或重新授权对象权限。
2. 在scott用户下创建视图权限不足:
使用sys登陆:CONN SYS/change_on_install AS SYSDBA;
授权:GRANT CREATE VIEW TO SCOTT;
切换回SCOTT: conn scott/tiger;
3. 视图是一个查询的结果,并不表示真实的数据,所以理论上视图是不应该被修改的,但是默认情况下如果不进行任何的配置,视图的数据是可以被修改的(简单情况)
方法一:创建视图时添加with check option,创建视图时作为查询条件的字段,如果作为修改时的条件,修改就会报错,但是其他字段仍能被修改
方法二:with read only:将其配置为只读视图,对于视图的创建强烈建议都设为只读模式
4.视图修改:
直接创建同名视图即可
视图的删除:DROP VIEW VIEW_NAME
删除视图的定义不影响基表中的数据。
只有视图所有者和具备DROP VIEW权限的用户可以删除视图。
视图被删除后,基于被删除视图的其他视图或应用将无效
oracle 创建索引和视图相关推荐
- Oracle创建索引、视图SQL语句
一.索引 1.添加索引 create index 索引对象名 on 索引对应表名(表内索引对象字段名); 例:需创建包含userid属性的userinfo表. create index userid ...
- ORACLE创建索引思路
ORACLE创建索引思路 何为索引 索引是一种数据结构,是为了更快速的访问到数据. 索引是各种关系数据库系统最常见的一种逻辑单元,是关系数据库系统举足轻重的重要组成部分,对于提高检索数据速度有着至关重 ...
- oracle怎么么创建索引,Oracle 创建索引,oracle索引怎么创建
Oracle 创建索引,oracle索引怎么创建 索引是数据库服务器用来加快检索的速度,再通过加了索引的列进行检索 时候,数据库会自动使用索引,使用索引所在的列值进行快速检索,快速定位到 真实的数据内 ...
- oracle创建索引占用表空间吗,oracle创建索引表空间
或者 drop tablespace 表空间名称 including contents;(表空间下有数据时候用) temporary tablespace 是 oracle 里临时表空间,临时表空间主 ...
- oracle创建带参数视图6,Oracle创建带有参数的视图代码介绍
在Oracle里,视图不像存储过程和函数一样,可以定义输入参数,但我们可以变个方式,使用程序包来实现 首先定义程序包: /* 按个人需要定义,我定义三个参数 ,因我项目程序需要,所以三个参数都是num ...
- oracle 创建索引 CREATE INDEX
CREATE INDEX -- 定义一个新索引 Synopsis CREATE [ UNIQUE ] INDEX name ON table [ USING method ]( { column | ...
- oracle添加索引指定表空间,Oracle 创建索引表空间语法-oracle
Oracle 的索引可分为5种,它们包括唯一索引.组合索引.反向键索引.位图索引和基于函数的索引. 1.创建索引的标准语法 以下为引用内容: CREATE INDEX 索引名 ON 表名 (列名)T ...
- oracle创建索引表,Oracle 大表创建索引
Oracle 大表创建索引 祖仙教小凡仙 海鲨数据库架构师 有个2亿记录的表,发现需要添加一个联合索引,结果就采用普通的create index index_name on tablename (en ...
- Oracle 创建索引语法
Oracle 的索引可分为5种,它们包括唯一索引.组合索引.反向键索引.位图索引和基于函数的索引. 1.创建索引的标准语法 以下为引用内容: CREATE INDEX 索引名 ON 表名 (列名)TA ...
最新文章
- 字节一面:Redis主节点的Key已过期,但从节点依然读到过期数据....
- GUI编程---贪吃蛇小游戏开发
- 动态路由协议RIP的基本原理与配置
- python 中if __name__ = '__main__' 的作用
- 引用校长对于管理工程学的学术研究的思考
- 制作验证码使用到的函数
- 易智瑞大赛——地图故事组参赛经验
- 很牛的求职经历(转载)
- 微信小程序登陆流程详详详解 看这一篇就够了
- 人类简史-读书笔记之历史演变图
- implicit super constructor animal() is undefined for default constructor. Must define an explicit 异常
- Springboot + vue 实现导出word
- 学习笔记——SDRAM学习
- Linux上安装NetCat
- git bash shell 脚本 :从文件获取git仓库列表 git clone所有仓库
- 个人随笔/记录一个博友推荐的截图工具《FSCapture》
- 分布式处理系统服务器配置,分布式解决方案
- uni-app 页面跳转
- 如何优雅的使用 win10
- ik 和hanlp_结巴分词和自然语言处理HanLP处理手记