一:    创建索引有两种方式:

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 创建索引和视图相关推荐

  1. Oracle创建索引、视图SQL语句

    一.索引 1.添加索引 create index 索引对象名 on 索引对应表名(表内索引对象字段名); 例:需创建包含userid属性的userinfo表. create index userid ...

  2. ORACLE创建索引思路

    ORACLE创建索引思路 何为索引 索引是一种数据结构,是为了更快速的访问到数据. 索引是各种关系数据库系统最常见的一种逻辑单元,是关系数据库系统举足轻重的重要组成部分,对于提高检索数据速度有着至关重 ...

  3. oracle怎么么创建索引,Oracle 创建索引,oracle索引怎么创建

    Oracle 创建索引,oracle索引怎么创建 索引是数据库服务器用来加快检索的速度,再通过加了索引的列进行检索 时候,数据库会自动使用索引,使用索引所在的列值进行快速检索,快速定位到 真实的数据内 ...

  4. oracle创建索引占用表空间吗,oracle创建索引表空间

    或者 drop tablespace 表空间名称 including contents;(表空间下有数据时候用) temporary tablespace 是 oracle 里临时表空间,临时表空间主 ...

  5. oracle创建带参数视图6,Oracle创建带有参数的视图代码介绍

    在Oracle里,视图不像存储过程和函数一样,可以定义输入参数,但我们可以变个方式,使用程序包来实现 首先定义程序包: /* 按个人需要定义,我定义三个参数 ,因我项目程序需要,所以三个参数都是num ...

  6. oracle 创建索引 CREATE INDEX

    CREATE INDEX -- 定义一个新索引 Synopsis CREATE [ UNIQUE ] INDEX name ON table [ USING method ]( { column | ...

  7. oracle添加索引指定表空间,Oracle 创建索引表空间语法-oracle

    Oracle 的索引可分为5种,它们包括唯一索引.组合索引.反向键索引.位图索引和基于函数的索引. 1.创建索引的标准语法 以下为引用内容:  CREATE INDEX 索引名 ON 表名 (列名)T ...

  8. oracle创建索引表,Oracle 大表创建索引

    Oracle 大表创建索引 祖仙教小凡仙 海鲨数据库架构师 有个2亿记录的表,发现需要添加一个联合索引,结果就采用普通的create index index_name on tablename (en ...

  9. Oracle 创建索引语法

    Oracle 的索引可分为5种,它们包括唯一索引.组合索引.反向键索引.位图索引和基于函数的索引. 1.创建索引的标准语法 以下为引用内容: CREATE INDEX 索引名 ON 表名 (列名)TA ...

最新文章

  1. 字节一面:Redis主节点的Key已过期,但从节点依然读到过期数据....
  2. GUI编程---贪吃蛇小游戏开发
  3. 动态路由协议RIP的基本原理与配置
  4. python 中if __name__ = '__main__' 的作用
  5. 引用校长对于管理工程学的学术研究的思考
  6. 制作验证码使用到的函数
  7. 易智瑞大赛——地图故事组参赛经验
  8. 很牛的求职经历(转载)
  9. 微信小程序登陆流程详详详解 看这一篇就够了
  10. 人类简史-读书笔记之历史演变图
  11. implicit super constructor animal() is undefined for default constructor. Must define an explicit 异常
  12. Springboot + vue 实现导出word
  13. 学习笔记——SDRAM学习
  14. Linux上安装NetCat
  15. git bash shell 脚本 :从文件获取git仓库列表 git clone所有仓库
  16. 个人随笔/记录一个博友推荐的截图工具《FSCapture》
  17. 分布式处理系统服务器配置,分布式解决方案
  18. uni-app 页面跳转
  19. 如何优雅的使用 win10
  20. ik 和hanlp_结巴分词和自然语言处理HanLP处理手记

热门文章

  1. MOOC微信小程序开发从入门到实践~笔记
  2. 第八节 Electron主进程和渲染进程之间的通信
  3. Smart3D(ContextCapture)跑三维到底要啥配置?!40000元来组建建模集群
  4. 浏览器窗口切换(从一个页面切换到另一个页面并且不刷新)
  5. 添加了validaterequest=false 为什么还是报错
  6. 防止360浏览器小窗下载视频
  7. Linux攻关之基础模块十二 进程相关
  8. Maven_怎么查看maven本地仓库地址
  9. windows7修改(缩小)快捷方式箭头
  10. 理解CMMI 3级过程域非常好的例子