亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

如何監控Oracle索引的使用完全解析

2024-08-29 13:51:26
字體:
來源:轉載
供稿:網友
研究發現,Oracle數據庫使用的索引不會超過總數的25%,或者不易他們期望被使用的方式使用。通過 監控數據庫索引的使用,釋放那些未被使用的索引,從而節省維護索引的開銷,優化性能。 1、在oracle8i中,確定使用了那個索引的方法意味著要對存在語共享SQL區中的所有語句運行EXPLIAN PALN,然后查詢計劃表中的OperaTION列,從而識別有OBJECT_OWNER和OBJECT_NAME列所確定的那個索引上的索引訪問。 下面是一個監控索引使用的腳本,這個腳本僅僅是一個樣品,在某種條件下成立: 條件: 運行這個腳本的用戶擁有權限解釋所有的v$sqlarea中的sql,除了不是被SYS裝載的。plan_table.remarks能夠別用來決定與特權習慣的錯誤。對所有的共享池中SQL,參數OPTIMIZER_GOAL是一個常量,無視v$sqlarea.optimizer_mode。兩次快照之間,統計資料被再次分析過。沒有語句別截斷。所有的對象都是局部的。所有被引用的表或視圖或者是被運行腳本的用戶所擁有,或者完全有資格的名字或同義詞被使用。自從上次快照以來,沒有不受"歡迎"的語句被沖洗出共享池(例如,在裝載)。對于所有的語句,v$sqlarea.version_count = 1 (children)。 腳本:
  Code: [Copy to clipboard]  set echo off  Rem Drop and recreate PLAN_TABLE for EXPLAIN PLAN  drop table plan_table;  create table PLAN_TABLE (  statement_id     varchar2(30),  timestamp      date,  remarks       varchar2(80),  operation      varchar2(30),  options        varchar2(255),  object_node     varchar2(128),  object_owner     varchar2(30),  object_name     varchar2(30),  object_instance    numeric,  object_type     varchar2(30),  optimizer      varchar2(255),  search_columns     number,  id            numeric,  parent_id        numeric,  position        numeric,  cost        numeric,  cardinality        numeric,  bytes        numeric,  other_tag      varchar2(255),  partition_start   varchar2(255),  partition_stop   varchar2(255),  partition_id    numeric,  other        long,  distribution    varchar2(30),  cpu_cost        numeric,  io_cost        numeric,  temp_space        numeric,  access_PRedicates  varchar2(4000),  filter_predicates  varchar2(4000));    Rem Drop and recreate SQLTEMP for taking a snapshot of the SQLAREA  drop table sqltemp;  create table sqltemp  (  ADDR         VARCHAR2 (16),  SQL_TEXT         VARCHAR2 (2000),  DISK_READS        NUMBER,  EXECUTIONS        NUMBER,  PARSE_CALLS     NUMBER);    set echo on  Rem Create procedure to populate the plan_table by executing  Rem explain plan...for 'sqltext' dynamically  create or replace procedure do_explain (  addr IN varchar2, sqltext IN varchar2)  as dummy varchar2 (1100);  mycursor integer;  ret integer;  my_sqlerrm varchar2 (85);  begin dummy:='EXPLAIN PLAN SET STATEMENT_ID=' ;  dummy:=dummy''''addr'''' ' FOR 'sqltext;  mycursor := dbms_sql.open_cursor;  dbms_sql.parse(mycursor,dummy,dbms_sql.v7);  ret := dbms_sql.execute(mycursor);  dbms_sql.close_cursor(mycursor);  commit;  exception -- Insert errors into PLAN_TABLE...  when others then my_sqlerrm := substr(sqlerrm,1,80);  insert into plan_table(statement_id,
remarks) values (addr,my_sqlerrm);  -- close cursor if exception raised on EXPLAIN PLAN  dbms_sql.close_cursor(mycursor);  end;  /    Rem Start EXPLAINing all S/I/U/D statements in the shared pool  declare  -- exclude statements with v$sqlarea.parsing_schema_id = 0 (SYS)  cursor c1 is select address, sql_text, DISK_READS, EXECUTIONS, PARSE_CALLS  from v$sqlarea  where command_type in (2,3,6,7)  and parsing_schema_id != 0;  cursor c2 is select addr, sql_text from sqltemp;  addr2     varchar(16);  sqltext    v$sqlarea.sql_text%type;  dreads     v$sqlarea.disk_reads%type;  execs     v$sqlarea.executions%type;  pcalls     v$sqlarea.parse_calls%type;  begin open c1;  fetch c1 into addr2,sqltext, dreads,execs,pcalls;  while (c1%found) loop  insert into sqltemp values (addr2,sqltext,dreads,execs,pcalls);  commit;  fetch c1 into addr2, sqltext,dreads,execs,pcalls;  end  loop;  close c1;  open c2;  fetch c2 into addr2, sqltext;  while (c2%found) loop  do_explain(addr2,sqltext);  fetch c2 into addr2, sqltext;  end  loop;  close c2;  end;  /    Rem Generate a report of index usage based on the number of times  Rem a SQL statement using that index was executed  select p.owner, p.name, sum(s.executions) totexec  from sqltemp s,  (select distinct statement_id stid, object_owner owner, object_name name  from plan_table where operation = 'INDEX') p  where s.addr = p.stid  group by p.owner, p.name  order by 2 desc;    Rem Perform cleanup on exit (optional)  delete from plan_table  where statement_id in  ( select addr from sqltemp );  drop table sqltemp;
關于這個腳本,有幾個重要的地方需要注重,即它可能一起明顯的開銷,因此,應該在仔細地進行 權衡后才把它應用到繁忙的生產應用系統中區。 2、oracle9i中如何確定索引的使用情況: 在oracle9i中,情況會簡單得多,因為有一個新得字典視圖V$SQL_PLAN存儲了實際計劃,這些計劃用于執行共享SQL區中得語句。V$SQL_PLAN視圖很類似與計劃表,但V$SQL_PLAN使用ADDRESS和HASH_VALUE列 來識別語句, 而計劃表使用用戶提供得STATEMENT_ID來識別語句。下面的SQL顯示了在一個oracle9i數據庫中,由出現在共享SQL區中語句使用的所有索引。
   select object_owner, object_name, options, count(*)  from  v$sql_plan  where operation='INDEX'  and  object_owner!='SYS'  group by object_owner, object_name, operation, options  order by count(*) desc;
所有基于共享SQL區中的信心來識別索引使用情況的方法, 都可能會收集到不完整的信息。共享SQL區是一 個動態結構,除非能對它進行足夠頻繁的采樣, 否則在有關索引使用的情況的信息被收集之前,SQL語句可 能就已經(因為老化)被移出緩存了。oracle9i提供了解決這個問題的方案,即它為alter index提供了一個monitoring usage子句。當啟用monitoring usage 時,oralce記錄簡單的yes或no值,以指出在監控間隔 期間某個索引是否被使用。 為了演示這個新特性,你可以使用下面的例子:   (a) Create and populate a small test table   (b) Create Primary Key index on that table   (c) Query v$object_usage: the monitoring has not started yet   (d) Start monitoring of the index usage   (e) Query v$object_usage to see the monitoring in progress
  (f) Issue the SELECT statement which uses the index   (g) Query v$object_usage again to see that the index has been used   (h) Stop monitoring of the index usage   (i) Query v$object_usage to see that the monitoring sDetailed steps
    (a) Create and populate a small test table  create table prodUCts  (  prod_id number(3),  prod_name_code varchar2(5));    insert into products values(1,'aaaaa');  insert into products values(2,'bbbbb');  insert into products values(3,'ccccc');  insert into products values(4,'ddddd');  commit;    (b) Create Primary Key index on that table  alter table products  add (constraint products_pk primary key (prod_id));    (c) Query v$object_usage: the monitoring has not started yet  column


上一篇:Oracle數據庫經典優化之索引原理篇

下一篇:完全攻略Oracle數據庫的備份與恢復

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品视频最多的网站| 欧美日韩亚洲国产一区| 亚洲欧美日韩精品久久亚洲区| 国产亚洲免费的视频看| 在线中文字幕日韩| 欧美国产日本高清在线| 亚洲人成在线观看网站高清| 久久免费视频这里只有精品| 亚洲a一级视频| 精品国产成人av| 国产91九色视频| 成人免费在线视频网站| 免费不卡在线观看av| 中文字幕不卡在线视频极品| 日韩在线一区二区三区免费视频| 羞羞色国产精品| 精品国产网站地址| 亚洲老板91色精品久久| 亚洲第一网站男人都懂| 亚洲va国产va天堂va久久| 欧美xxxx综合视频| 久色乳综合思思在线视频| 欧美激情第一页xxx| 亚洲福利视频免费观看| 91精品在线一区| 国产精品黄页免费高清在线观看| 91免费人成网站在线观看18| 国产精品扒开腿做爽爽爽男男| 91久久精品一区| 欧美性一区二区三区| 91九色国产视频| 日韩在线观看免费高清| 亚洲第一页在线| 久久久之久亚州精品露出| 亚洲韩国青草视频| 不卡中文字幕av| 亚洲美女av在线播放| 国产成人精品免高潮在线观看| 97在线观看免费高清| 亚洲欧美国产一区二区三区| 欧美日韩美女在线| 日韩美女中文字幕| 国产精品久久久久久av福利| 日韩av快播网址| 欧美精品久久久久a| 国产精品久久久久av| 国产精品欧美一区二区三区奶水| 欧美性猛交xxxx乱大交| 欧美日韩福利电影| 色综久久综合桃花网| 久久在线精品视频| 中文字幕精品在线视频| 久久精品99久久久香蕉| 亚洲国产精品电影在线观看| 亚洲国产精品人人爽夜夜爽| 78色国产精品| 国产精品成久久久久三级| 亚洲成人黄色网| 亚洲精品少妇网址| 亚洲片在线观看| 久久夜色精品国产亚洲aⅴ| www.久久草.com| 成人亚洲综合色就1024| 亚洲欧美在线x视频| 亚洲天堂精品在线| 国产va免费精品高清在线观看| 久久99久久99精品中文字幕| 黑人巨大精品欧美一区免费视频| 综合网日日天干夜夜久久| 日韩av网站电影| 亚洲欧美制服中文字幕| 亚洲人成亚洲人成在线观看| 97色在线视频| 日韩成人性视频| 久久久久久久久综合| 91免费版网站入口| 国产精品视频免费在线观看| 午夜精品一区二区三区在线| 亚洲精品国产精品乱码不99按摩| 亚洲一区二区三区乱码aⅴ| 亚洲国产日韩欧美综合久久| 国产精品国模在线| 亚洲性猛交xxxxwww| 欧美伊久线香蕉线新在线| 国产有码在线一区二区视频| 综合网日日天干夜夜久久| 欧美色视频日本高清在线观看| 欧美在线视频网| 国产香蕉一区二区三区在线视频| 国产视频福利一区| 亚洲少妇中文在线| 色偷偷88888欧美精品久久久| 欧美日韩国产中文精品字幕自在自线| 国产不卡av在线免费观看| 中文综合在线观看| 性夜试看影院91社区| 国产精品亚洲第一区| 欧美限制级电影在线观看| 久久精品最新地址| 国产欧美久久一区二区| 精品一区二区三区四区在线| 国产亚洲精品美女久久久久| 久久久人成影片一区二区三区| 久久久91精品国产| 久久久久久12| 奇门遁甲1982国语版免费观看高清| 91精品国产自产在线观看永久| 欧美日韩国产影院| 国产精品中文字幕久久久| 国产精品一区二区性色av| 亚洲午夜精品久久久久久性色| 国产一区二区香蕉| 欧美视频专区一二在线观看| 国产精品直播网红| 欧美综合国产精品久久丁香| 91精品在线播放| 91精品国产色综合| 欧美成人免费一级人片100| 亚洲香蕉成人av网站在线观看| 97av在线视频免费播放| 亚洲国产女人aaa毛片在线| 尤物九九久久国产精品的特点| 精品欧美激情精品一区| 成人精品视频久久久久| 中文字幕欧美精品日韩中文字幕| 国产精品com| 精品亚洲一区二区三区四区五区| 国产精品丝袜视频| 亚洲第一黄色网| 亚洲视频视频在线| 亚洲人成亚洲人成在线观看| 久久久亚洲网站| 91综合免费在线| 91久久精品视频| 欧美激情在线狂野欧美精品| 亚洲成av人乱码色午夜| 日韩国产欧美区| 日韩高清电影免费观看完整版| 日韩免费高清在线观看| 丝袜美腿精品国产二区| 美女少妇精品视频| 亚洲娇小xxxx欧美娇小| 欧美日韩激情美女| 91夜夜揉人人捏人人添红杏| 日韩精品极品在线观看播放免费视频| 91精品国产免费久久久久久| 国产精品热视频| 97在线视频免费观看| 丝袜亚洲另类欧美重口| 成人伊人精品色xxxx视频| 欧美成人免费va影院高清| 亚洲免费成人av电影| www国产亚洲精品久久网站| 欧美日韩一区二区精品| 日韩av影视在线| 中文国产亚洲喷潮| 在线日韩欧美视频| 亚洲欧美精品一区二区| 亚洲高清久久久久久| 精品亚洲va在线va天堂资源站| 欧美激情啊啊啊| 欧美日韩黄色大片| 51ⅴ精品国产91久久久久久| 亚洲黄色在线看|