oracle 创建索引和视图

 

oracle 创建索引和视图_第1张图片

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

 

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权限的用户可以删除视图。
        视图被删除后,基于被删除视图的其他视图或应用将无效

 

 

 

       

 

 

 

 

 

 

 

 

 

 

 

 

你可能感兴趣的:(数据库)