视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Oracle提高sql执行效率的心得建议
2020-11-09 13:48:52 责编:小采
文档


sql执行效率一直都是为人所关注,那到底应该怎样提高呢?有什么比较好的方法,下面与大家分享下比较不错的建议,感兴趣的朋友可以参考下,希望对大家有所帮助 代码如下:

--FROM子句中包含多个表的情况下,选择记录条数最少的表作为基础表 --解析WHER

sql执行效率一直都是为人所关注,那到底应该怎样提高呢?有什么比较好的方法,下面与大家分享下比较不错的建议,感兴趣的朋友可以参考下,,希望对大家有所帮助

代码如下:
-->FROM子句中包含多个表的情况下,选择记录条数最少的表作为基础表

-->解析WHERE子句是自下而上的 过滤条件要有顺序

-->ORACLE会将'*'转换成列名

-->DELETE会在rollback segment中存放可恢复信息,可以试试TRUNCATE

-->COMMIT会释放:1.rollback segment
2.被程序语句获得的锁
3.redo log buffer

-->把Alias前缀于每个Column上可以减少解析的时间

-->ORACLE解析sql语句时会把小写的字母转换成大写的再执行

-->在索引列上使用NOT会停止使用索引转而执行全表扫描

-->在索引列上进行运算会停止使用索引转而执行全表扫描

-->使用'>=',而不是'>'

-->where子句中'!='、'||'、'+'等符号会破坏索引

-->IN的效率很低,IN子句将执行一个内部的排序和合并

-->EXIST查询更为迅速

-->对于两个索引列,UNION比OR效率更高

-->IS NULL会破坏索引

-->DISTINCT,UNION,MINUS,INTERSECT,ORDER BY等都带有SORT功能,会耗费资源

-->多个索引列时尽量使用第一个索引列

-->尽量用 UNION ALL代替UNION

-->不要用TO_NUMBER()之类的函数改变索引列的类型。

-->对于字符类型的索引列尽量写成:col = '123' 而不是 col = 123,后者会被解析为TO_NUMBER(EMP_TYPE)=123

-->适当的地方使用适当的关键字:HAVING会在检索出所有记录之后对结果集进行过滤 能使用WHERE解决时不要用HAVING

-->索引也需要维护,INSERT,DELETE,UPDATE会因索引而做出更多次I/O

-->重构索引是必要的:ALTER INDEX REBUILD [ONLINE]

详细出处参考:

下载本文
显示全文
专题