一:SQL tuning 類(lèi)
1:列舉幾種表連接方式
hash join/merge join/nest loop(cluster join)/index join
2:不借助第三方工具,怎樣查看sql的執(zhí)行計(jì)劃
set autot on
explain plan set statement_id = &item_id for &sql;
select * from table(dbms_xplan.display);
https://download-west.oracle.com/ ... /b10752/ex_plan.htm
3:如何使用CBO,CBO與RULE的區(qū)別
在optimizer_mode=choose時(shí),如果表有統(tǒng)計(jì)信息(分區(qū)表外),優(yōu)化器將選擇CBO,否則選RBO。RBO遵循簡(jiǎn)單的分級(jí)方法學(xué),使用15種級(jí)別要點(diǎn),當(dāng)接收到查詢(xún),優(yōu)化器將評(píng)估使用到的要點(diǎn)數(shù)目, 然后選擇最佳級(jí)別(最少的數(shù)量)的執(zhí)行路徑來(lái)運(yùn)行查詢(xún)。
CBO嘗試找到最低成本的訪問(wèn)數(shù)據(jù)的方法,為了最大的吞吐量或最快的初始響應(yīng)時(shí)間,計(jì)算使用不同 的執(zhí)行計(jì)劃的成本,并選擇成本最低的一個(gè),關(guān)于表的數(shù)據(jù)內(nèi)容的統(tǒng)計(jì)被用于確定執(zhí)行計(jì)劃。
4:如何定位重要(消耗資源多)的SQL
select sql_text
from v$sql
where disk_reads > 1000 or (executions > 0 and buffer_gets/executions > 30000);
5:如何跟蹤某個(gè)session的SQL
exec dbms_system.set_sql_trace_in_session(sid,serial#,&sql_trace);
select sid,serial# from v$session where sid = (select sid from v$mystat where rownum = 1);
exec dbms_system.set_ev(&sid,&serial#,&event_10046,&level_12,'');
6:SQL調(diào)整最關(guān)注的是什么
查看該SQL的response time(db block gets/consistent gets/physical reads/sorts (disk))
7:說(shuō)說(shuō)你對(duì)索引的認(rèn)識(shí)(索引的結(jié)構(gòu)、對(duì)dml影響、為什么提高查詢(xún)性能)
b-tree index/bitmap index/function index/patitional index(local/global) 索引通常能提高select/update/delete的性能,會(huì)降低insert的速度,
8:使用索引查詢(xún)一定能提高查詢(xún)的性能嗎?為什么
索引就是為了提高查詢(xún)性能而存在的, 如果在查詢(xún)中索引沒(méi)有提高性能, 只能說(shuō)是用錯(cuò)了索引,或者講是場(chǎng)合不同
9:綁定變量是什么?綁定變量有什么優(yōu)缺點(diǎn)?
綁定變量是相對(duì)文本變量來(lái)講的,所謂文本變量是指在SQL直接書(shū)寫(xiě)查詢(xún)條件,這樣的SQL在不同條件下需要反復(fù)解析,綁定變量是指使用變量來(lái)代替直接書(shū)寫(xiě)條件,查詢(xún)bind value在運(yùn)行時(shí)傳遞,然后綁定執(zhí)行。優(yōu)點(diǎn)是減少硬解析,降低CPU的爭(zhēng)用,節(jié)省shared_pool ;缺點(diǎn)是不能使用histogram,sql優(yōu)化比較困難
10:如何穩(wěn)定(固定)執(zhí)行計(jì)劃
query_rewrite_enabled = true
star_transformation_enabled = true
optimizer_features_enable = 9.2.0
創(chuàng)建并使用stored outline
https://download-west.oracle.com/ ... /outlines.htm#26854
11:和排序相關(guān)的內(nèi)存在8i和9i分別怎樣調(diào)整,臨時(shí)表空間的作用是什么
8i中sort_area_size/sort_area_retained_size決定了排序所需要的內(nèi)存
如果排序操作不能在sort_area_size中完成,就會(huì)用到temp表空間
9i中如果workarea_size_policy=auto時(shí),
排序在pga內(nèi)進(jìn)行,通常pga_aggregate_target的1/20可以用來(lái)進(jìn)行disk sort;
如果workarea_size_policy=manual時(shí),排序需要的內(nèi)存由sort_area_size決定
在執(zhí)行order by/group by/distinct/union/create index/index rebuild/minus等操作時(shí),
如果在pga或sort_area_size中不能完成,排序?qū)⒃谂R時(shí)表空間進(jìn)行(disk sort),
臨時(shí)表空間主要作用就是完成系統(tǒng)中的disk sort.
12:存在表T(a,b,c,d),要根據(jù)字段c排序后取第21—30條記錄顯示,請(qǐng)給出sql
create table t(a number(,b number(,c number(,d number();
/
begin
for i in 1 .. 300 loop
insert into t values(mod(i,2),i/2,dbms_random.value(1,300),i/4);
end loop;
end;
/
select * from (select c.*,rownum as rn from (select * from t order by c desc) c) where rn between 21 and 30;
/
select * from (select * from test order by c desc) x where rownum
相比之 minus性能較差
二、數(shù)據(jù)庫(kù)基本概念類(lèi)
1:pctused and pctfree 表示什么含義有什么作用
pctused與pctfree控制數(shù)據(jù)塊是否出現(xiàn)在freelist中,
pctfree控制數(shù)據(jù)塊中保留用于update的空間,當(dāng)數(shù)據(jù)塊中的free space小于pctfree設(shè)置的空間時(shí),
該數(shù)據(jù)塊從freelist中去掉,當(dāng)塊由于dml操作free space大于pct_used設(shè)置的空間時(shí),該數(shù)據(jù)庫(kù)塊將
被添加在freelist鏈表中。
2:簡(jiǎn)單描述table / segment / extent / block之間的關(guān)系
table創(chuàng)建時(shí),默認(rèn)創(chuàng)建了一個(gè)data segment,
每個(gè)data segment含有min extents指定的extents數(shù),
每個(gè)extent據(jù)據(jù)表空間的存儲(chǔ)參數(shù)分配一定數(shù)量的blocks
3:描述tablespace和datafile之間的關(guān)系
一個(gè)tablespace可以有一個(gè)或多個(gè)datafile,每個(gè)datafile只能在一個(gè)tablespace內(nèi),
table中的數(shù)據(jù),通過(guò)hash算法分布在tablespace中的各個(gè)datafile中,
tablespace是邏輯上的概念,datafile則在物理上儲(chǔ)存了數(shù)據(jù)庫(kù)的種種對(duì)象。
4:本地管理表空間和字典管理表空間的特點(diǎn),ASSM有什么特點(diǎn)
本地管理表空間(Locally Managed Tablespace簡(jiǎn)稱(chēng)LMT)
8i以后出現(xiàn)的一種新的表空間的管理模式,通過(guò)位圖來(lái)管理表空間的空間使用。