oracle数据库sql的优化总结
自己对⏫oracle sql的一些📛优化总结,自己也【zì jǐ yě】记录下来【lái】,也希望🥃对大家有帮助【yǒu bāng zhù】:
一:使用where少使用having;
二:查两张【chá liǎng zhāng】🔧以上表【yǐ shàng biǎo】🤸时🧗,把记录少的放【shǎo de fàng】在右边;
三:减少对表的访问次数;
四【sì】:有【yǒu】🐭where子查询时🚶,子查询放在最🛷前【qián】;
五【wǔ】📻:select语句中尽量避🗒免使用*(执行时会把🐨*依次转【yī cì zhuǎn】换为列名【míng】);
六:尽量多的使用commit;
七:Decode可以避🍉免重复扫描相【sǎo miáo xiàng】🏡同的记🔄录或重复连接【fù lián jiē】相同的表【biǎo】;
八:通过内部函数也可提高sql效率;
九🌨:连接多🕕个表时,使用别名并把【míng bìng bǎ】别名前缀于每个字段【gè zì duàn】💶上【shàng】;
十:用exists代替in
十一:not exists代替【dài tì】🌆 not in(not in 字句将🛶执行一【zhí háng yī】个内部【gè nèi bù】📛的排序和合并,任何情况下,not in是最低【shì zuì dī】效的🐿,子查询中全表扫描了。为了避🈲免使用【miǎn shǐ yòng】not in,可以改写成outer joins或【huò】🌬not exists);
十二:表连接比exists更高效;
十三:用【yòng】🥍exists替换distinct
例【lì】👖:
低: 高【gāo】❓:
select distinct dept_no, dept_name select dept_no, dept_name
from dept d, emp e from dept d
where d.dept_no = e.dept_no; where exists (select 1 from emp e where e.dept_no = d.dept_no);
十四:使用🎓TKPROF工具来查询【chá xún】sql性能状【xìng néng zhuàng】🆑态;
十五:用索引【yòng suǒ yǐn】提高效🌄率(代价是【dài jià shì】🐒:索引需要空间,而且定【ér qiě dìng】期重构💭索引很🏡有必要【yǒu bì yào】:ALTER INDEX<INDEXNAME> REBUILD<TABLESPACENAME);
先介绍【xiān jiè shào】🎳下索引【xià suǒ yǐn】的原理【de yuán lǐ】,方便接下来对😊索引的优化的🏩理解:
通过【guò】索引找到rowid,然后通🦑过【guò】rowid访问表【fǎng wèn biǎo】🎓。但如果【dàn rú guǒ】查询的列包括在index中♓,将不在执行第二部操🛸作,因为检【yīn wéi jiǎn】📩索数据保存在【bǎo cún zài】索引中【suǒ yǐn zhōng】♓,单单访【dān dān fǎng】🐦问索引🕹就可以【jiù kě yǐ】完全满足查询🎲要求。
前提提要✒:在十六【zài shí liù】例中🐤,LODGING列有唯🐤一索引【yī suǒ yǐn】;MANAGER列上有非唯一【fēi wéi yī】性索引。
十六:索引范围查询【wéi chá xún】🌤(INDEX RANGE SACEN):
适用于【shì yòng yú】两种情况🚝:
1)基于一【jī yú yī】✒个范围的查询:
SELECT LODGING FROM LODGING WHERE LODGING LIKE 'M%'
(where字句条【zì jù tiáo】🐭件包括【jiàn bāo kuò】一系列【yī xì liè】的值🕵,oracle将通过索引范围查询方式查👝询LODGING_PK)
2) 基于非【jī yú fēi】🤓唯一性🍓索引的检索【jiǎn suǒ】:
SELECT LODGING FROM LODGING WHERE MANAGER = 'LI';
(此查询分两步:LODGING$MANAGER的索引【de suǒ yǐn】范围查【fàn wéi chá】询得到🌅所有符【suǒ yǒu fú】合条件记录的rowid,然后通【rán hòu tōng】🤰过🍫rowid访问表得到🌅LODGING列的值。该索引【yǐn】🔢为非唯【wéi fēi wéi】一性索引【yǐn】,数据库不能对🌇它执行🌳索引唯【suǒ yǐn wéi】一扫描✋)
where字句中📡,如果索【rú guǒ suǒ】引列所对应的🏠值的第【zhí de dì】一个字🚀符由通配符开📽始,索引将【suǒ yǐn jiāng】不被采【bú bèi cǎi】用【yòng】,而会全🐝表扫描,如 SELECT..... WHERE MANAGER LIKE '%LI'
十七:基础表的选择:
基础表【jī chǔ biǎo】📌:最先访【zuì xiān fǎng】🏊问🎖的表(通常以全表扫【quán biǎo sǎo】描的方式被访问🎖)。
根据优化器的【huà qì de】💤不同,SQL语句中🤲基础表的选择【de xuǎn zé】是不一【shì bú yī】🚂样的:
如果使【rú guǒ shǐ】用【yòng】CBO,优化器【yōu huà qì】🤧会检查SQL语句中📳的每个表的物理大小,索引的🍮状态【zhuàng tài】,然后选用话费【yòng huà fèi】🍮最低的路径🤛。
如果使【rú guǒ shǐ】用【yòng】RBO,并且所有的连接条件都有索🛢引对应🕚,这种情况下基础表就是【shì】♊FROM字句中🎑列在最【liè zài zuì】👷后的表【hòu de biǎo】
例【lì】💿:
SELECT A.NAME, B.MANAGER FROM WOKER A, LODGING B WHERE A.LODGING = B.LODGING;
由于LODGING列上有一个索【yī gè suǒ】引🍸,而且WORKER表【biǎo】中没🛬有相比🎓较的索引🍸,WORKER表将被【biǎo jiāng bèi】作为查【zuò wéi chá】询基础🎛表【biǎo】。
十八:多个平等的索引:
当【dāng】🍓SQL语句的执行路径可以🎶使用分布在多个表上的多个🚍索引时【suǒ yǐn shí】,oracle会同事使用多个索引【gè suǒ yǐn】并【bìng】🈺在运行时对它们的🌌记录合【jì lù hé】🚌并【bìng】🈺,检索仅对全部索引有【suǒ yǐn yǒu】效的记录【lù】✍。
oracle选择执行路径🈯是【shì】🥂,唯一索引【yī suǒ yǐn】🏻等级高于非唯一索引【yī suǒ yǐn】🏻,只有当where字句中索引🏻列和常量比较【liàng bǐ jiào】才【cái】📅有效【yǒu xiào】。如果索引🏻列和其它表的索引✖列相比🛂较🏅,这种字【zhè zhǒng zì】🐢句在优【jù zài yōu】化器中【huà qì zhōng】等级非常低【cháng dī】;
如果不同表中【tóng biǎo zhōng】🕡两个相同等级🎀的索引【de suǒ yǐn】💲将被引【jiāng bèi yǐn】⏸用,根据✡FROM字句中【zì jù zhōng】👞表的顺序决定哪个先🏸被使用。FROM字句中【zì jù zhōng】👞最后的表索引【biǎo suǒ yǐn】优先级【xiān jí】高。如果相【rú guǒ xiàng】🏁同表中【tóng biǎo zhōng】🕡两个相同等级🎀的索引【de suǒ yǐn】💲将被引【jiāng bèi yǐn】⏸用,where字句中【zì jù zhōng】👞最先被【zuì xiān bèi】🤔引用的索引【de suǒ yǐn】💲将有最高的优先级【xiān jí】。
例🖱:DEPTNO上有非唯一性【wéi yī xìng】👇索引【suǒ yǐn】🎶,EMP_CAT也有非【yě yǒu fēi】唯一性【wéi yī xìng】👇索引【suǒ yǐn】🎶
SELECT ENAME FROM EMP WHERE DEPT_NO = 20 AND EMP_CAT = 'A';
DEPTNO索引将被先检索,然后同EMP_CAT索引检【suǒ yǐn jiǎn】索出的结果合✔并,执行路【zhí háng lù】🔜径如下【jìng rú xià】🅰:
TABLE ACCESS BY ROWID ON EMP
AND _EQUAL
INDEX RANGE SCAN ON DEPT_IDX
INDEX RANGE SCAN ON CAT_IDX
十九:等式比较与范围比较:
先上例【xiān shàng lì】🐽子:
SELECT ENAME FROM EMP WHERE DEPT_NO > 20 AND EMP_CAT = 'A';
(在两个非唯一【fēi wéi yī】性索引🏋前提下)此时范围索引【wéi suǒ yǐn】不被使【bú bèi shǐ】用【yòng】🧐,通过【tōng guò】EMP_CAT索引查询出记🍖录再与🏎DEPT_NO条件进🗺行比较
注意【zhù yì】🍛:唯一性所以做🎓范围比🐿较时【jiào shí】,等级要比非唯一性索引的等【yǐn de děng】🤖式比较低【dī】;
二十:强制索引失效:
如果两【rú guǒ liǎng】个或两【gè huò liǎng】😧个以上索引具🥢有相同的等级,可以强【kě yǐ qiáng】制命令🌚oracle优化器使用其【shǐ yòng qí】中的一【zhōng de yī】🦗个。 那何时🏜使用此【shǐ yòng cǐ】种策略呢?如果一个索引已接近🐦于唯一,而另一🚼索引有很多重复的值📬,排序与【pái xù yǔ】🍴合并反而会成为负担,此时可【cǐ shí kě】以屏蔽【yǐ píng bì】后者使其索引💶失效【shī xiào】。
(失效方【shī xiào fāng】🏙式:对索引列加入👕计算'+0'或【huò】'||""');
关键词:oracle,数据库
阅读本文后您有什么感想? 已有 人给出评价!
- 0
- 0
- 0
- 0
- 0
- 0