{"id":182,"date":"2008-03-03T15:22:00","date_gmt":"2008-03-03T18:22:00","guid":{"rendered":"http:\/\/www.soudba.com.br\/?p=182"},"modified":"2008-03-03T15:22:00","modified_gmt":"2008-03-03T18:22:00","slug":"recriar-os-indices-fragmentados","status":"publish","type":"post","link":"https:\/\/www.soudba.com.br\/?p=182","title":{"rendered":"Recriar os indices fragmentados"},"content":{"rendered":"<p>Recriacao dos indices \u00e9 uma tarefa constante do DBA, se os indices estao fragmentados, pode ser penoso ao banco de dados, percorrer os indices para que eles possam informar a localizacao da informacao da qual buscamos.<br \/>Entao, outro dia precisei de recriar os indices que estavam fragmentados. Entao porque nao, criar um script para que o proprio banco, no domingo a noite, uma vez por semana fizesse isso?<\/p>\n<p>Assim, o script abaixo foi transformado em uma procedure da qual, criei um job para rodar no domingo.<\/p>\n<p>########################## INICIO PROCEDURE<\/p>\n<p>CREATE OR REPLACE  PROCEDURE &#8220;SYS&#8221;.&#8221;PROC_CRIAINDICEFRAG&#8221;  is<br \/>begin<br \/>\/* Sao dois blocos identicos, para garantir que os indices foram recriados *\/ <br \/>FOR cur_rec IN<br \/>(SELECT  &#8216;alter index &#8216;||table_owner||&#8217;.&#8217;||index_name||&#8217; rebuild tablespace &#8216;|| tablespace_name||&#8217; &#8216; myddl<br \/>FROM DBA_indexes<br \/>WHERE blevel &gt;=4<br \/>&#8212; and ROWNUM &lt;=1<br \/>) loop<br \/>   execute immediate cur_rec.myddl;<br \/> \/*<br \/> if l_status != &#8216;OK&#8217; then<br \/>    dbms_output.put_line(&#8216;error&#8217;);<br \/> end if;<br \/> *\/<br \/> END LOOP;<\/p>\n<p> FOR cur_rec IN<br \/>(SELECT  &#8216;alter index &#8216;||table_owner||&#8217;.&#8217;||index_name||&#8217; rebuild tablespace &#8216;|| tablespace_name||&#8217; &#8216; myddl<br \/>FROM DBA_indexes<br \/>WHERE blevel &gt;=4<br \/>&#8212; and ROWNUM &lt;=1<br \/>) loop<br \/>   execute immediate cur_rec.myddl;<br \/> \/*<br \/> if l_status != &#8216;OK&#8217; then<br \/>    dbms_output.put_line(&#8216;error&#8217;);<br \/> end if;<br \/> *\/<br \/> END LOOP;<\/p>\n<p>end;<\/p>\n<p>################################################# FIM PROCEDURE<br \/>&#8212; Bloco de chamada dentro do JOB<\/p>\n<p>begin<br \/>  SYS.PROC_CRIAINDICEFRAG;<br \/>end;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Recriacao dos indices \u00e9 uma tarefa constante do DBA, se os indices estao fragmentados, pode ser penoso ao banco de dados, percorrer os indices para que eles possam informar a localizacao da informacao da qual buscamos.Entao, outro dia precisei de &hellip; <a href=\"https:\/\/www.soudba.com.br\/?p=182\">Continue lendo <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[110,119,189,195,240],"tags":[],"class_list":["post-182","post","type-post","status-publish","format-standard","hentry","category-fragmentacao-de-indices","category-indice-fragmentado","category-oracle","category-oracle-indice","category-recriar-indices-fragmentados"],"_links":{"self":[{"href":"https:\/\/www.soudba.com.br\/index.php?rest_route=\/wp\/v2\/posts\/182","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.soudba.com.br\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.soudba.com.br\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.soudba.com.br\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.soudba.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=182"}],"version-history":[{"count":0,"href":"https:\/\/www.soudba.com.br\/index.php?rest_route=\/wp\/v2\/posts\/182\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.soudba.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=182"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.soudba.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=182"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.soudba.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=182"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}