oracle 批量 重建索引,Oracle重建索引Shell脚本、SQL脚本分享

索引是提高数据库查询性能的有力武器。没有索引,就好比图书馆没有图书标签一样,找一本书自己想要的书比登天还难。然而索引在使用的过程中,尤其是在批量的DML的情形下会产生相应的碎片,以及B树高度会发生相应变化,因此可以对这些变化较大的索引进行重构以提高性能。N久以前Oracle建议我们定期重建那些高度为4,已删除的索引条目至少占有现有索引条目总数的20%的这些表上的索引。但Oracle现在强烈建议不要定期重建索引。具体可以参考文章:Oracle 重建索引的必要性。尽管如此重建索引还是有必要的,只是不建议定期。本文给出了重建索引的脚本供大家参考。

1、重建索引shell脚本

robin@SZDB:~/dba_scripts/custom/bin> more rebuild_unbalanced_indices.sh

# +-------------------------------------------------------+

# + Rebulid unblanced indices |

# + Author : Leshami |

# + Parameter : No |

# +-------------------------------------------------------+

#!/bin/bash

# --------------------

# Define variable

# --------------------

if [ -f ~/.bash_profile ]; then

. ~/.bash_profile

fi

DT=`date +%Y%m%d`; export DT

RETENTION=1

LOG_DIR=/tmp

LOG=${LOG_DIR}/rebuild_unbalanced_indices_${DT}.log

DBA=Leshami@12306.cn

# ------------------------------------

# Loop all instance in current server

# -------------------------------------

echo "Current date and time is : `/bin/date`">>${LOG}

for db in `ps -ef | grep pmon | grep -v grep |grep -v asm |awk '{print $8}'|cut -c 10-`

do

echo "$db"

export ORACLE_SID=$db

echo "Current DB is $db" >>${LOG}

echo "===============================================">>${LOG}

$ORACLE_HOME/bin/sqlplus -S /nolog @/users/robin/dba_scripts/custom/sql/rebuild_unbalanced_indices.sql>>${LOG}

done;

echo "End of rebuilding index for all instance at : `/bin/date`">>${LOG}

# -------------------------------------

# Check log file

# -------------------------------------

status=`grep "ORA-" ${LOG}`

if [ -z $status ];then

mail -s "Succeeded rebuilding indices on `hostname` !!!" ${DBA}

else

mail -s "Failed rebuilding indices on `hostname` !!!" ${DBA}

fi

# ------------------------------------------------

# Removing files older than $RETENTION parameter

# ------------------------------------------------

find ${LOG_DIR} -name "rebuild_unb*" -mtime +$RETENTION -exec rm {} \;

exit

2、重建索引调用的SQL脚本

robin@SZDB:~/dba_scripts/custom/sql> more rebuild_unbalanced_indices.sql

conn / as sysdba

set serveroutput on;

DECLARE

resource_busy EXCEPTION;

PRAGMA EXCEPTION_INIT (resource_busy, -54);

c_max_trial CONSTANT PLS_INTEGER := 10;

c_trial_interval CONSTANT PLS_INTEGER := 1;

pmaxheight CONSTANT INTEGER := 3;

pmaxleafsdeleted CONSTANT INTEGER := 20;

CURSOR csrindexstats

IS

SELECT NAME,

height,

lf_rows AS leafrows,

del_lf_rows AS leafrowsdeleted

FROM index_stats;

vindexstats csrindexstats%ROWTYPE;

CURSOR csrglobalindexes

IS

SELECT owner,index_name, tablespace_name

FROM dba_indexes

WHERE partitioned = 'NO'

AND owner IN ('GX_ADMIN');

CURSOR csrlocalindexes

IS

SELECT index_owner,index_name, partition_name, tablespace_name

FROM dba_ind_partitions

WHERE status = 'USABLE'

AND index_owner IN ('GX_ADMIN');

trial PLS_INTEGER;

vcount INTEGER := 0;

BEGIN

trial := 0;

/* Global indexes */

FOR vindexrec IN csrglobalindexes

LOOP

EXECUTE IMMEDIATE

'analyze index ' || vindexrec.owner ||'.'|| vindexrec.index_name || ' validate structure';

OPEN csrindexstats;

FETCH csrindexstats INTO vindexstats;

IF csrindexstats%FOUND

THEN

IF (vindexstats.height > pmaxheight)

OR ( vindexstats.leafrows > 0

AND vindexstats.leafrowsdeleted > 0

AND (vindexstats.leafrowsdeleted * 100 / vindexstats.leafrows) >

pmaxleafsdeleted)

THEN

vcount := vcount + 1;

DBMS_OUTPUT.PUT_LINE (

'Rebuilding index ' || vindexrec.owner ||'.'|| vindexrec.index_name || '...');

<>

BEGIN

EXECUTE IMMEDIATE

'alter index '

|| vindexrec.owner ||'.'

|| vindexrec.index_name

|| ' rebuild'

|| ' parallel nologging compute statistics'

|| ' tablespace '

|| vindexrec.tablespace_name;

EXCEPTION

WHEN resource_busy OR TIMEOUT_ON_RESOURCE

THEN

DBMS_OUTPUT.PUT_LINE (

'alter index - busy and wait for 1 sec');

DBMS_LOCK.sleep (c_trial_interval);

IF trial <= c_max_trial

THEN

GOTO alter_index;

ELSE

DBMS_OUTPUT.PUT_LINE (

'alter index busy and waited - quit after '

|| TO_CHAR (c_max_trial)

|| ' trials');

RAISE;

END IF;

WHEN OTHERS

THEN

DBMS_OUTPUT.PUT_LINE ('alter index err ' || SQLERRM);

RAISE;

END;

END IF;

END IF;

CLOSE csrindexstats;

END LOOP;

DBMS_OUTPUT.PUT_LINE ('Global indices rebuilt: ' || TO_CHAR (vcount));

vcount := 0;

trial := 0;

/* Local indexes */

FOR vindexrec IN csrlocalindexes

LOOP

EXECUTE IMMEDIATE

'analyze index '

|| vindexrec.index_owner||'.'

|| vindexrec.index_name

|| ' partition ('

|| vindexrec.partition_name

|| ') validate structure';

OPEN csrindexstats;

FETCH csrindexstats INTO vindexstats;

IF csrindexstats%FOUND

THEN

IF (vindexstats.height > pmaxheight)

OR ( vindexstats.leafrows > 0

AND vindexstats.leafrowsdeleted > 0

AND (vindexstats.leafrowsdeleted * 100 / vindexstats.leafrows) >

pmaxleafsdeleted)

THEN

vcount := vcount + 1;

DBMS_OUTPUT.PUT_LINE (

'Rebuilding index ' || vindexrec.index_owner||'.'|| vindexrec.index_name || '...');

<>

BEGIN

EXECUTE IMMEDIATE

'alter index '

|| vindexrec.index_owner||'.'

|| vindexrec.index_name

|| ' rebuild'

|| ' partition '

|| vindexrec.partition_name

|| ' parallel nologging compute statistics'

|| ' tablespace '

|| vindexrec.tablespace_name;

EXCEPTION

WHEN resource_busy OR TIMEOUT_ON_RESOURCE

THEN

DBMS_OUTPUT.PUT_LINE (

'alter partitioned index - busy and wait for 1 sec');

DBMS_LOCK.sleep (c_trial_interval);

IF trial <= c_max_trial

THEN

GOTO alter_partitioned_index;

ELSE

DBMS_OUTPUT.PUT_LINE (

'alter partitioned index busy and waited - quit after '

|| TO_CHAR (c_max_trial)

|| ' trials');

RAISE;

END IF;

WHEN OTHERS

THEN

DBMS_OUTPUT.PUT_LINE (

'alter partitioned index err ' || SQLERRM);

RAISE;

END;

END IF;

END IF;

CLOSE csrindexstats;

END LOOP;

DBMS_OUTPUT.PUT_LINE ('Local indices rebuilt: ' || TO_CHAR (vcount));

END;

/

exit;

3、输入日志样本

Current date and time is : Sun Apr 20 02:00:02 HKT 2014

Current DB is SYBO2 ===============================================

Rebuilding index GX_ADMIN.SYN_OUT_DATA_TBL_PK...

Rebuilding index GX_ADMIN.IDX_TDBK_SPLNK_PARENT_REF...

Rebuilding index GX_ADMIN.IDX_TDBK_SPLNK_CHILD_REF...

Rebuilding index GX_ADMIN.PK_TRADE_BROKER_TBL...

Rebuilding index GX_ADMIN.IDX_TDBK_INPUT_DATE...

................

4、后记

a、如果同一台服务器上有多个实例,且每个实例有相同的schema,此脚本会轮巡所有实例并根据analyze结果来rebuild。

a、大家应根据需要作相应调整,如脚本的路径信息等。

b、需要修改相应的schema name。

d、可根据系统环境调整相应的并行度。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/489589.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

pandas 学习(二)—— pandas 下的常用函数

import pandas as pd; 1. 数据处理函数 pd.isnull()/pd.notnull()&#xff1a;用于检测缺失数据&#xff1b;2. 辅助函数 pd.to_datetime()3. Series 与 DataFrame 的成员函数 drop(labels, axis0, levelNone, inplaceFalse, errors’raise’) 注意第一个参数&#xff08;label…

python中set index_python中set基础应用

set:类似dict,是一组key的集合&#xff0c;不存储value本质是无序和无重复元素的集合#创建#创建set需要一个list或者tuple或者dict作为输入集合s1set({1,2,3,4,5})s2set({1,2,2,5,3,3,5})s3set({1:"123",2:"daf"})print(s1)#{1, 2, 3, 4, 5}print(s2)#{1, …

【智能驾驶】自动驾驶深度感知技术对车和行人的检测

来源&#xff1a;小马智行第二场技术沙龙今天我主要想分享自动驾驶感知技术在探索的过程中&#xff0c;采用的传统方法和深度学习方法。传统方法不代表多传统&#xff0c;深度学习也不代表多深度。它们有各自的优点&#xff0c;也都能解决各自的问题&#xff0c;最终希望将其结…

matlab读取其他位置,将文件的数据读取到matlab中,进行编辑,然后将其保存到其他位置...

将文件的数据读取到matlab中&#xff0c;进行编辑&#xff0c;然后将其保存到其他位置 我有一个名为EXP1_SQ1_Template.txt的文件。这是一个简单的文本文件&#xff0c;包含以下8行&#xff1a;LOAD BOX 1 SUBJ M1_299633_D295158_JUN191910_Aut_ERROR2 EXPT St(m)_Se(n)_Rat1 …

oracle 11g安装过程中问题:找不到WFMLRSVCApp.ear

网上的方法是将两个压缩包解压到同一个目录中&#xff0c;我的方法是不再此解压&#xff0c;麻烦&#xff0c;直接将解压出的内容剪切过去&#xff0c;方便省事&#xff0c;原理也是相同的。解决方法&#xff1a; 将win64_11gR2_database_2of2解压出的文件&#xff0c;\win64_1…

python字符串随机排序_python 随机数使用方法,推导以及字符串,双色球小程序实例...

#随机数的使用import random #导入randomrandom.randint(0,9)#制定随机数0到9irandom.sample(range(1,34),6)#输出6个随机数&#xff0c;范围是1到34i.sort()#排序方法&#xff0c;排序时更改原数组&#xff0c;无返回值sorted(i)#排序函数&#xff0c;排序时不影响原数组&…

中国信通院《新型智慧城市发展研究报告》

来源&#xff1a;云头条本报告结合新时期我国新型智慧城市的建设重点&#xff0c;围绕顶层设计、体制机制、智能基础设施、智能运行中枢、智慧生活、智慧生产、智慧治理、智慧生态、技术创新与标准体系和安全保障体系等十大核心要素&#xff0c;深入分析研究了我国新型智慧城市…

python处理一亿条数据_Python基础数据处理库

Numpy 简介import numpy as npNumpy是应用Python进行科学计算的基础库。它的功能包括多维数组、基本线性代数、基本统计计算、随机模拟等。Numpy的核心功能是ndarray 类&#xff0c;即多维数组。多维数组是线性代数中非常广泛的概念&#xff0c;如一维数组就是向量&#xff0c;…

oracle 内存分析工具,IDE 中的分析工具

IDE 中的分析工具Oracle Solaris Studio IDE 提供的交互式图形分析工具可用于检查在 IDE 内部运行的项目的性能。分析工具使用 Oracle Solaris Studio 实用程序和操作系统实用程序来收集数据。可通过 "Profile Project"(分析项目)按钮使用分析工具。Monitor Project(…

python中x y 1_Python的X[y==1, 0]

最近研究逻辑回归&#xff0c;Iris花的经典示例&#xff0c;代码就不全粘贴了&#xff0c;具体代码参看“Iris花逻辑回归与实现”1 plt.plot(X[y0, 0], X[y0,1], "bs")2 plt.plot(X[y1, 0], X[y1, 1], "g^")X[y0, 0]中的y0是个什么东东&#xff0c;为什么可…

关于直播,所有的技术细节都在这里了(2)《转载》

本文转载置顶&#xff1a;http://blog.ucloud.cn/archives/694 感谢作者无私的奉献精神&#xff01; 上篇《 关于直播&#xff0c;所有的技术细节都在这里了(1)《转载》 》我们讲述了如何让直播内容以“最短”路径从主播到观众上&#xff0c;传输层面获得最低延迟&#xff0c;在…

光刻机的工作原理及关键技术

来源&#xff1a;传感器技术光刻机的工作原理&#xff1a;利用光刻机发出的光通过具有图形的光罩对涂有光刻胶的薄片曝光&#xff0c;光刻胶见光后会发生性质变化&#xff0c;从而使光罩上得图形复印到薄片上&#xff0c;从而使薄片具有电子线路图的作用。这就是光刻的作用&…

sarscape 将dem文件转化成stl_SARscape与SARProz软件中的重要缩写

1.SARscapeSARscape 由 sarmap 公司研发&#xff0c;是国际知名的雷达图像处理软件。 该软件架构于专业的ENVI 遥感图像处理软件之上&#xff0c;提供完整的 SAR 数据处理功能&#xff0c;全面支持四种模式的数据&#xff1a;雷达强度图像处理、雷达干涉测量(InSAR/DInSAR)、极…

很全的路由器默认初始密码集合.txt_UpSet——集合关系可视化神器

学习更多生信小技巧&#xff0c;点上方蓝字关注我们分析背景01提到集合的可视化&#xff0c;大家第一时间想到的是用Venn图来展示&#xff0c;在前期的推文中&#xff0c;小编也给大家分享了venn图的绘制方法。然而&#xff0c;值得一提的是&#xff0c;小编分享的方法是基于R语…

imp-00017 oracle2298,急,imp怪異問題,請高手協助

我原有系統平台是:window2003 32位oracle9.0 32位版本&#xff0c;現exp導出dmp文件后&#xff0c;想倒入到linux 64位 oracle10。2.0.4 64位平台上&#xff0c;但倒了幾次老提示以下錯誤。請高手協助&#xff0c;謝謝。IMP-00041: 警告&#xff1a;創建的對象帶有編譯警告&quo…

自动驾驶的摩尔定律:无人驾驶的最终实现时间或在2035年丨厚势汽车

来源&#xff1a;厚势汽车 无人驾驶的真正落地时间的预测&#xff0c;近两年从非常乐观迅速转向谨慎甚至悲观。真正的无人驾驶到底还需要多久&#xff0c;无人驾驶初创公司 May Mobility 的 CEO Edwin Olson&#xff0c;针对这个问题&#xff0c;结合已有的数据做了一个推理。他…

电脑屏保海底世界_世界上最后一个深海实验室,隐藏了人类未来的秘密

如果世界末日来了&#xff0c;人类站在荒废的土地上&#xff0c;仓皇奔往未来的逃生门&#xff0c;我们应该往哪去&#xff1f;有人说&#xff0c;是太空。有人说&#xff0c;是海洋。现在有一个地方&#xff0c;正把两者结合起来——Aquarius Reef Base 深海实验室。这个处于海…

oracle 怎么备份sqlserver数据库,Oracle和sqlserver数据库的备份与恢复

Oracle 数据库的备份与恢复当我们使用一个数据库时&#xff0c;总希望数据库的内容是可靠的、正确的&#xff0c;但由于计算机系统的故障(包括机器故障、介质故障、误操作等)&#xff0c;数据库有时也可能遭到破坏&#xff0c;这时如何尽快恢复数据就成为当务之急。如果平时对数…

Android——检查网络是否已经链接

新建一个项目testNet 添加一个button layout.xml&#xff1a; <RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android"xmlns:tools"http://schemas.android.com/tools"android:layout_width"match_parent"android:layou…

自学python在家怎么上班_【经验分享】转行如何自学Python并且找到工作,分享自己心得...

目前信息化产业发展势头很好&#xff0c;互联网就成为了很多普通人想要涉及的行业&#xff0c;因为相比于传统行业&#xff0c;互联网行业涨薪幅度大&#xff0c;机会也多&#xff0c;所以就会大批的人想要转行来学习Python开发。零基础学习Python必须明确的几点&#xff1a;1.…