Oracle 10g SQL ÓÅ»¯ÔÙѧϰ
´Ó8iµ½10g£¬Oracle²»¶Ï½ø»¯×Ô¼ºµÄSQL TuningÖÇÄÜ£¬Ò»Ð©Ãؼ®¼¶µÄÓÅ»¯¿Ú¾÷ÒѾʧЧ¡£
µ«ÎÒϲ»¶Ê§Ð§£¬²»Óüǿھ÷£¬²Ù¸öToad for Oracle Xpert
£¬°´ÕÕ´ó·½ÏòÊæÊæ·þ·þµÄ
µ÷ÓŲÅÊǰ®×öµÄÊÂÇé¡£
1.Excution Plan
Excution
PlanÊÇ×î»ù±¾µÄµ÷ÓŸÅÄ²»¹ÜÄãµÄµ÷ÓÅ´µµÃÈçºÎÌ컨ÂҶ飬½á¹û»¹ÊÇÒªÓÉExcution planÀ´ÏÔʾOracle
×îÖÕÓÃʲôË÷Òý¡¢°´Ê²Ã´Ë³ÐòÁ¬½Ó¸÷±í£¬Full Table Scan»¹ÊÇAccess by Rowid
Index£¬Æ¿¾±ÔÚʲôµØ·½¡£Èç¹ûûÓÐËüµÄÖ¸µ¼£¬Ò»Çе÷ÓŶ¼ÊÇÃɵġ£
2.Toad for Oracle
Xpert
ÓÃËüÀ´µ÷ÓÅÔÚÕæµÄºÃÊæ·þ¡£Quest
ÍÌ
²¢ÁËLeccoºó£¬½«ËüÕûºÏµ½ÁËToad µÄSQL
TunningÀïÃæ£º×îÇåÎúµÄÖ´Ðмƻ®ÏÔʾ£¬×Ô¶¯Éú³ÉNÌõµÈ¼ÛSQL¡¢¸ø³öÓÅ»¯½¨Ò飬²»Í¬SQLÖ´Ðмƻ®µÄ¶Ô±È£¬»¹ÓÐʵ¼ÊÖ´ÐеÄÂß¼¶Á¡¢ÎïÀí¶ÁÊý¾ÝµÈµÈÒ»
Ä¿ÁËÈ»¡£
3.Ë÷Òý
´ó²¿·ÖµÄÐÔÄÜÎÊÌâÆäʵ¶¼ÊÇË÷ÒýÓ¦ÓõÄÎÊÌ⣬Where×Ӿ䡢
Order By¡¢Group By ¶¼ÒªÓõ½Ë÷Òý¡£
Ò»°ã¿ª·¢ÈËÔ±ÈÏΪ½«Ë÷Òý½¨È«Á˾ͿÉÒÔÏ塈ȯ¼ÒÁË£¬ÊµÔò»¹ÓÐÆÄ¶àµÄ˼Á¿ºÍÏÝÚå¡£
3.1
Ë÷ÒýÁÐÉϲ»Òª½øÐмÆËã
ÕâÊÇ×î×îÆÕ±éµÄʧЧÏÝÚ壬±ÈÈçwhere
trunc(order_date)=trunc(sysdate),
i+2>4¡£Ë÷ÒýʧЧµÄÔÒòÒ²¼òµ¥£¬Ë÷ÒýÊÇÕë¶ÔÔÖµ½¨µÄ¶þ²æÊ÷£¬Ä㽫ÁÐÖµ*3/4+2ÕÛÌÚÒ»·¬ºó£¬ÔÀ´µÄ¶þ²æÊ÷µ±È»¾ÍÓò»ÉÏÁË¡£½â¾öµÄ·½·¨:
¡¡
1.¡¡»»³ÉµÈ¼ÛÓï·¨£¬±ÈÈçtrunc(order_date) »»³É
where order_date
>
trunc(sysdate)
-
1
and
order_date
<
trunc(sysdate)
+
1
¡¡ 2. ÌØ±ðΪ¼ÆË㽨Á¢º¯ÊýË÷Òý
create
index
£É_XXXX
on
shop_order(trunc(order_date))
3. ½«¼ÆËã´ÓµÈºÅ×ó±ßÒÆµ½ÓÒ±ß
¡¡ÕâÊÇÕë¶ÔijЩÎÞÐÄ֮ʧµÄ¾ÀÕý£¬°Ña*2>4¡¡¸ÄΪa>4/2£»°Ñ
TO_CHAR(zip) = '94002' ¸ÄΪzip = TO_NUMBER('94002');
3.2
CBOÓëË÷ÒýÑ¡ÔñÐÔ
½¨ÁËË÷ÒýÒ²²»Ò»¶¨»á±»OracleÓõ쬾ÍÏñ¸öÌôʳµÄº¢×Ó¡£»ùÓڳɱ¾µÄÓÅ»¯Æ÷(CBO,
Cost-Based Optimizer)£¬»áÏÈ¿´¿´±íµÄ´óС£¬»¹ÓÐË÷ÒýµÄÖØ¸´¶È£¬ÔÙ¾ö¶¨Óû¹ÊDz»ÓᣱíÖÐÓÐ100 Ìõ¼Ç¼¶øÆäÖÐÓÐ80
¸ö²»Öظ´µÄË÷Òý¼üÖµ. Õâ¸öË÷ÒýµÄÑ¡ÔñÐÔ¾ÍÊÇ80/100 =
0.8£¬ÁôÒâToadÀïÏÔʾË÷ÒýµÄSelectiveº
Ïà¹ØÎĵµ£º
create database test --½¨Á¢testÊý¾Ý¿â
use test
create table BONUS --½¨Á¢
(
ENAME NVARCHAR(10),
JOB NVARCHAR(9),
SAL FLOAT,
COMM FLOAT
)
create table DEPT --½¨Á¢²¿Ãűí
(
DEPTNO SMALLINT not null, --²¿ÃűàºÅ
DNAME NVARCHAR(14), --²¿ÃÅÃû
LOC NVARC ......
±íÖÐÖ÷¼ü±ØÐëΪ±êʶÁУ¬[ID] int IDENTITY (1,1)
1.·ÖÒ³·½°¸Ò»£º(ÀûÓÃNot InºÍSELECT TOP·ÖÒ³)
Óï¾äÐÎʽ£º
SELECT TOP Ò³¼Ç¼ÊýÁ¿ *
from ±íÃû
WHERE (ID NOT IN
(SELECT TOP (ÿҳÐÐÊý*(Ò³Êý-1)) ID
from ±íÃû
ORDER BY ID))
ORDER BY ID
//×Ô¼º»¹¿ÉÒÔ¼ÓÉÏһЩ²é ......
SQL Server 2005£¨ÊÊÓÃÓÚ2000£©µÄÐ¶ÔØÊÇÒ»¸ö·Ç³£Í·ÌÛµÄÎÊÌâ¡£ÎÒÔø¾³¢ÊÔ¹ýÖ±½ÓʹÓá¾Ìí¼Ó»òɾ³ý³ÌÐò¡¿¹¤¾ßÐ¶ÔØ¡¢Çå³ý°²×°Ä¿Â¼¡¢É¾³ý×¢²á±íÄÚÈݵȵȸ÷ÖÖ·½Ê½×ÛºÏÐ¶ÔØ£¬ÃãÇ¿³É¹¦¡£ÏÖÔÚÖÕÓÚÕÒµ½ÁËÒ»¸öʰ빦±¶µÄ·½·¨£¬¶à´Î³¢ÊÔ£¬Î´ÓÐʧ°Ü,¾ßÌåÈçÏÂ:
1.ÏÂÔØÐ¶ÔØ¹¤¾ß£¬ÓÐÁ½ÖÖ£º
µÚÒ»ÖÖÊÇ΢Èí¹Ù·½ÌṩµÄ¹¤¾ß(msicuu2.exe)
http ......
Oracle
SQL
µÄÓÅ»¯¹æ
Ôò£º
¾¡Á¿ÉÙÓÃIN²Ù×÷·û£¬»ù±¾ÉÏËùÓеÄIN²Ù×÷·û¶¼¿ÉÒÔÓÃEXISTS´úÌæ
ÓÃINд³öÀ´µÄSQL
µÄÓŵãÊDZȽÏÈÝÒ×д¼°ÇåÎúÒ×¶®£¬µ«ÊÇÓÃINµÄSQL
ÐÔÄÜ×ÜÊDZȽϵ͵쬴ÓORACLE
Ö´
ÐеIJ½ÖèÀ´·ÖÎöÓÃINµÄSQL
Óë²»ÓÃINµÄSQL
ÓÐ
ÒÔÏÂÇø±ð£º
......