聽聽聽 CBO鏂瑰紡錛?/strong>瀹冩槸鐪嬭鍙ョ殑浠d環(Cost),榪欓噷鐨勪唬浠蜂富瑕佹寚Cpu鍜屽唴瀛樸備紭鍖栧櫒鍦ㄥ垽鏂槸鍚︾敤榪欑鏂瑰紡鏃?涓昏鍙傜収鐨勬槸琛ㄥ強绱㈠紩鐨勭粺璁′俊鎭傜粺璁′俊鎭粰鍑鴻〃鐨勫ぇ灝忋佹湁灝戣銆佹瘡琛岀殑闀垮害絳変俊鎭傝繖浜涚粺璁′俊鎭搗鍒濆湪搴撳唴鏄病鏈夌殑錛屾槸鍋歛nalyze鍚庢墠鍑虹幇鐨勶紝寰堝鐨勬椂渚繃鏈熺粺璁′俊鎭細浠や紭鍖栧櫒鍋氬嚭涓涓敊璇殑鎵ц璁″垝,鍥犱簺搴斿強鏃舵洿鏂拌繖浜涗俊鎭?/p> 聽聽聽 浼樺寲妯″紡鍖呮嫭Rule銆丆hoose銆丗irst rows銆丄ll rows鍥涚鏂瑰紡錛?/p> 聽聽聽 Rule錛氬熀浜庤鍒欑殑鏂瑰紡銆?/strong> 聽聽聽 Choolse錛?/strong>榛樿鐨勬儏鍐典笅Oracle鐢ㄧ殑渚挎槸榪欑鏂瑰紡銆傛寚鐨勬槸褰撲竴涓〃鎴栨垨绱㈠紩鏈夌粺璁′俊鎭紝鍒欒蛋CBO鐨勬柟寮忥紝濡傛灉琛ㄦ垨绱㈠紩娌$粺璁′俊鎭紝琛ㄥ張涓嶆槸鐗瑰埆鐨勫皬錛岃屼笖鐩稿簲鐨勫垪鏈夌儲寮曟椂錛岄偅涔堝氨璧扮儲寮曪紝璧癛BO鐨勬柟寮忋?/p> 聽聽聽 First Rows錛?/strong>瀹冧笌Choose鏂瑰紡鏄被浼肩殑錛屾墍涓嶅悓鐨勬槸褰撲竴涓〃鏈夌粺璁′俊鎭椂錛屽畠灝嗘槸浠ユ渶蹇殑鏂瑰紡榪斿洖鏌ヨ鐨勬渶鍏堢殑鍑犺錛屼粠鎬諱綋涓婂噺灝戜簡鍝嶅簲鏃墮棿銆?/p> 聽聽聽 All Rows:涔熷氨鏄垜浠墍璇寸殑Cost鐨勬柟寮忥紝褰撲竴涓〃鏈夌粺璁′俊鎭椂錛屽畠灝嗕互鏈蹇殑鏂瑰紡榪斿洖琛ㄧ殑鎵鏈夌殑琛岋紝浠庢諱綋涓婃彁楂樻煡璇㈢殑鍚炲悙閲忋傛病鏈夌粺璁′俊鎭垯璧癛BO鐨勬柟寮忋?/p> 聽聽聽 璁懼畾閫夌敤鍝浼樺寲妯″紡錛?/strong> 聽聽聽 A銆両nstance綰у埆鎴戜滑鍙互閫氳繃鍦╥nitSID.ora鏂囦歡涓瀹歄PTIMIZER_MODE=RULE/CHOOSE/FIRST_ROWS/ALL_ROWS濡傛灉娌¤瀹歄PTIMIZER_MODE鍙傛暟鍒欓粯璁ょ敤鐨勬槸Choose鏂瑰紡銆?br />聽聽聽 B銆丼essions綰у埆閫氳繃ALTER SESSION SET OPTIMIZER_MODE=RULE/CHOOSE/FIRST_ROWS/ALL_ROWS鏉ヨ瀹氥?br />聽聽聽 C銆佽鍙ョ駭鍒敤Hint錛?*+ ... */錛夋潵璁懼畾SELECT聽/**//*+聽ALL_ROWS聽*/聽employee_id,聽last_name,聽salary,聽job_id聽FROM聽employees聽WHERE聽employee_id聽=聽183;
]]>