oracle大表性能优化

1 不修改表结构的优化

1.1 收缩表,降低高水位线

ALTER TABLE TEST ENABLE ROW MOVEMENT;
ALTER TABLE TEST SHRINK SPACE;

1.2 对表收集统计信息

BEGIN
DBMS_STATS.GATHER_TABLE_STATS(ownname => user,
tabname => 'TEST');
END;

1.3 使用oracle的并行查询功能

SELECT /*+ parallel(4)*/* FROM test;

1.4 OR查询条件使用union all替代

1.5 多表联合查询时,在子查询中先写好过滤条件再关联别的表

1.6 DML比较慢时而且并发访问比较低的情况下,会话开启并行DML功能。

Alter session enable parallel dml;

1.7 在insert时使用直接加载和nologging方式插入数据

Insert /*+ append parallel(4)*/ into test nologging select * from YYY;

1.8 update大量数据时,可以使用先删除后插入的做法代替

2 修改表结构的优化

2.1 在筛选(where)少部分数据的字段上建立索引

2.2 如果查询(select)或者排序(order by)涉及的字段很少,可以在这些字段建立索引

2.3 如果建立了索引,索引没有生效,查询索引状态是否正常。索引为'UNUSABLE'状态要重建索引

2.4 往目标表插入数据时,可以将索引置为'UNUSABLE'状态,等插入数据后,再重建索引

alter index IDX_TEST unusable;

2.5 对表根据业务需求进行分区

2.6 尽可能的使用 varchar 代替 char ,因为首先变长字段存储空间小,可以节省存储空间

2.7 涉及LOB字段类型的表,将LOB字段放在一个单独的表空间。因为oracle默认不会缓存大于4000字节的LOB字段,直接从磁盘读写LOB。放在单独的表空间,从而减少对其他大部分对象的影响

2.8 查询表的行迁移情况,如果表行迁移的数据过多,就需要重新建表,同时合适设置PCTFREE,避免更新再次导致行迁移

3 在存储过程的优化

3.1 使用绑定变量的方式输入变量值

3.2 将大表按使用到的字段拆分成临时表(TEMPORARY TABLE)。后面使用临时表数据而不是大表数据参与计算。临时表产生的undo数据设置为放在临时表空间。拆分后,要对临时表收集统计信息

--临时表产生的undo数据设置为放在临时表空间
ALTER SESSION SET TEMP_UNDO_ENABLED = TRUE;
作者:追求完美9196原文地址:https://www.cnblogs.com/study9196/p/18320428

%s 个评论

要回复文章请先登录注册