一: 创建索引有两种方式:
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权限的用户可以删除视图。
视图被删除后,基于被删除视图的其他视图或应用将无效