数据库优化方案

上传人:M****1 文档编号:489961155 上传时间:2022-09-27 格式:DOC 页数:6 大小:31.50KB
返回 下载 相关 举报
数据库优化方案_第1页
第1页 / 共6页
数据库优化方案_第2页
第2页 / 共6页
数据库优化方案_第3页
第3页 / 共6页
数据库优化方案_第4页
第4页 / 共6页
数据库优化方案_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《数据库优化方案》由会员分享,可在线阅读,更多相关《数据库优化方案(6页珍藏版)》请在金锄头文库上搜索。

1、数据库优化方案1. 高效地进行SQL语句设计:通常情况下,可以采用下面的方法优化SQL对数据操作的表现:(1)减少对数据库的查询次数,即减少对系统资源的请求,使用快照和显形图等分布式数据库对象可以减少对数据库的查询次数。(2)尽量使用相同的或非常类似的SQL语句进行查询,这样不仅充分利用SQL共享池中的已经分析的语法树,要查询的数据在SGA中命中的可能性也会大大增加。(3)避免不带任何条件的SQL语句的执行。没有任何条件的SQL语句在执行时,通常要进行FTS,数据库先定位一个数据块,然后按顺序依次查找其它数据,对于大型表这将是一个漫长的过程.(4)如果对有些表中的数据有约束,最好在建表的SQL

2、语句用描述完整性来实现,而不是用SQL程序中实现。一、操作符优化:1、IN操作符用IN写出来的SQL的优点是比较容易写及清晰易懂,这比较适合现代软件开发的风格。但是用IN的SQL性能总是比较低的,从Oracle执行的步骤来分析用IN的SQL与不用IN的SQL有以下区别:ORACLE试图将其转换成多个表的连接,如果转换不成功则先执行IN里面的子查询,再查询外层的表记录,如果转换成功则直接采用多个表的连接方式查询。由此可见用IN的SQL至少多了一个转换的过程.一般的SQL都可以转换成功,但对于含有分组统计等方面的SQL就不能转换了。在业务密集的SQL当中尽量不采用IN操作符.优化sql时,经常碰到

3、使用in的语句,一定要用exists把它给换掉,因为Oracle在处理In时是按Or的方式做的,即使使用了索引也会很慢.2、 NOT IN操作符 强列推荐不使用的,因为它不能应用表的索引。用NOT EXISTS或(外连接+判断为空)方案代替3、IS NULL或IS NOT NULL操作判断字段是否为空一般是不会应用索引的,因为B树索引是不索引空值的。用其它相同功能的操作运算代替,a is not null改为 a0 或a等。不允许字段为空,而用一个缺省值代替空值,如业扩申请中状态字段不允许为空,缺省为申请.避免在索引列上使用IS NULL和IS NOT NULL 避免在索引中使用任何可以为空的

4、列,ORACLE将无法使用该索引对于单列索引,如果列包含空值,索引中将不存在此记录.对于复合索引,如果每个列都为空,索引中同样不存在此记录。如果至少有一个列不为空,则记录存在于索引中举例:如果唯一性索引建立在表的A 列和B 列上,并且表中存在一条记录的A,B 值为(123,null) , ORACLE 将不接受下一条具有相同A,B值(123,null)的记录(插入)。然而如果所有的索引列都为空,ORACLE将认为整个键值为空而空不等于空。因此你可以插入1000 条具有相同键值的记录,当然它们都是空!因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引.低

5、效: (索引失效)SELECT FROM DEPARTMENT WHERE DEPT_CODE ISNOTNULL;高效: (索引有效)SELECT FROM DEPARTMENT WHERE DEPT_CODE =0;4、及 =3的效果就有很大的区别了,因为A2时ORACLE会先找出为2的记录索引再进行比较,而A=3时ORACLE则直接找到=3的记录索引。用=替代高效:SELECT FROM DEPARTMENT WHERE DEPT_CODE =0;低效:SELECT*FROM EMPWHERE DEPTNO 3两者的区别在于, 前者DBMS将直接跳到第一个DEPT等于4的记录而后者将首先

6、定位到DEPT NO=3的记录并且向前扫描到第一个DEPT大于3的记录。5、LIKE操作符:LIKE操作符可以应用通配符查询,里面的通配符组合可能达到几乎是任意的查询,但是如果用得不好则会产生性能上的问题,如LIKE %5400%这种查询不会引用索引,而LIKEX5400则会引用范围索引.一个实际例子:用YW_YHJBQK表中营业编号后面的户标识号可来查询营业编号 YY_BH LIKE%5400 这个条件会产生全表扫描,如果改成YY_BH LIKE X5400% OR YY_BH LIKE B5400则会利用YY_BH的索引进行两个范围的查询,性能肯定大大提高。6、用EXISTS替换DISTI

7、NCT:当提交一个包含一对多表信息(比如部门表和雇员表)的查询时,避免在SELECT子句中使用DISTINCT。 一般可以考虑用EXIST 替换, EXISTS使查询更为迅速,因为RDBMS核心模块将在子查询的条件一旦满足后,立刻返回结果.例子:(低效):SELECTDISTINCT DEPT_NO,DEPT_NAMEFROM DEPT D , EMP EWHERE D.DEPT_NO = E。DEPT_NO(高效):SELECT DEPT_NO,DEPT_NAMEFROM DEPT D WHEREEXISTS(SELECTXFROM EMP EWHERE E。DEPT_NO = D。DEPT

8、_NO);如:用EXISTS 替代IN、用NOT EXISTS替代NOT IN:在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接.在这种情况下,使用EXISTS(或NOT EXISTS)通常将提高查询的效率。在子查询中,NOT IN 子句将执行一个内部的排序和合并。 无论在哪种情况下,NOT IN都是最低效的(因为它对子查询中的表执行了一个全表遍历).为了避免使用NOT IN ,我们可以把它改写成外连接(Outer Joins)或NOT EXISTS。例子:(高效):SELECT*FROM EMP (基础表)WHERE EMPNO 0ANDEXISTS(SELECTXFR

9、OM DEPTWHERE DEPT。DEPTNO= EMP.DEPTNO AND LOC=MELB)(低效):SELECTFROM EMP (基础表)WHERE EMPNO 0AND DEPTNOIN(SELECT DEP TNOFROM DEPT WHERE LOC =MELB)7、用UNION替换OR (适用于索引列)通常情况下, 用UNION替换WHERE 子句中的OR 将会起到较好的效果.对索引列使用OR 将造成全表扫描. 注意,以上规则只针对多个索引列有效.如果有column 没有被索引, 查询效率可能会因为你没有选择OR而降低。 在下面的例子中, LOC_ID和REGION 上都建

10、有索引. (高效):SELECT LOC_ID,LOC_DESC,REGIONFROM LOCATION WHERE LOC_ID =10UNIONSELECT LOC_ID , LOC_DESC , REGIONFROM LOCATION WHERE REGION =MELBOURNE(低效):SELECT LOC_ID,LOC_DESC,REGIONFROM LOCATION WHERE LOC_ID= 10OR REGION = MELBOURNE如果你坚持要用OR, 那就需要返回记录最少的索引列写在最前面.8、用IN来替换OR这是一条简单易记的规则,但是实际的执行效果还须检验,在ORA

11、CLE8i下,两者的执行路径似乎是相同的低效:SELECT。FROM LOCATION WHERE LOC_ID =10OR LOC_ID=20OR LOC_ID=30高效:SELECTFROM LOCATION WHERE LOC_IN IN (10,20,30);二、SQL语句结构优化1、SELECT子句中避免使用 :2、用TRUNCATE替代DELETE :用TRUNCATE替代DELETE删除全表记录:(大数据量的表用次方法)当删除表中的记录时,在通常情况下,回滚段(rollback segments )用来存放可以被恢复的信息. 如果你没有COMMIT 事务,ORACLE会将数据恢复

12、到删除之前的状态(准确地说是恢复到执行删除命令之前的状况)而当运用TRUNCATE 时, 回滚段不再存放任何可被恢复的信息。3、用Where子句替换HAVING 子句:避免使用HAVING 子句, HAVING 只会在检索出所有记录之后才对结果集进行过滤.这个处理需要排序,总计等操作。如果能通过WHERE 子句限制记录的数目,那就能减少这方面的开销. (非oracle中)on、where、having这三个都可以加条件的子句中,on是最先执行,where 次之,having 最后,因为on是先把不符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据,按理说应该速度是最快的, whe

13、re 也应该比having快点的4、sql语句用大写因为oracle 总是先解析sql语句,把小写的字母转换成大写的再执行。5、在Java代码中尽量少用连接符“”连接字符串!6、避免改变索引列的类型.:当比较不同数据类型的数据时, ORACLE自动对列进行简单的类型转换. 假设EMPNO 是一个数值类型的索引列.SELECT FROM EMP WHERE EMPNO = 123实际上,经过ORACLE类型转换, 语句转化为:SELECT FROM EMP WHERE EMPNO = TO_NUMBER(123)幸运的是,类型转换没有发生在索引列上,索引的用途没有被改变.现在,假设EMP_TYP

14、E是一个字符类型的索引列.SELECT FROM EMP WHERE EMP_TYPE =123这个语句被ORACLE转换为:SELECT FROM EMP WHERETO_NUMBER(EMP_TYPE)=123因为内部发生的类型转换, 这个索引将不会被用到! 为了避免ORACLE对你的SQL 进行隐式的类型转换,最好把类型转换用显式表现出来.注意当字符和数值比较时, ORACLE会优先转换数值类型到字符类型7、优化GROUP BY:提高GROUP BY 语句的效率, 可以通过将不需要的记录在GROUP BY之前过滤掉。下面两个查询返回相同结果但第二个明显就快了许多.低效:1SELECT J

15、OB,AVG(SAL)FROM EMP GROUPby JOBHAVING JOB= PRESIDENT OR JOB =MANAGER高效:1SELECT JOB,AVG(SAL)FROM EMP WHERE JOB =PRESIDENTOR JOB=MANAGERGROUPby JOB数据库优化方案1. 利用表分区分区将数据在物理上分隔开,不同分区的数据可以制定保存在处于不同磁盘上的数据文件里。这样,当对这个表进行查询时,只需要在表分区中进行扫描,而不必进行全表扫描,明显缩短了查询时间,另外处于不同磁盘的分区也将对这个表的数据传输分散在不同的磁盘I/O,一个精心设置的分区可以将数据传输对磁盘I/O竞争均匀地分散开。对数据量大的时时表可采取此方法.可按月自动建表分区。2. 别名的使用别名是大型数据库的应用技巧,就是表名、列名在查询中以一个字母为别名,查询速度要比建连接

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 商业/管理/HR > 创业/孵化

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号