数据库环境中的shell脚本应用

维护多个数据库,又没有EM,在各个数据库之间来回切换很是麻烦,
今天参照一些资料写了如下的shell脚本。主要来讲dba的账户密码,ORACLE_SID都以环境变量的形式注入,然后在当前session中可以灵活的切换实例来进行相应的操作。
比如想查看数据库中的表空间情况,可以在当前的session中查看其他数据库实例的数据情况。

export SH_USERNAME=system
export SH_PASSWORD=oracle
export ORACLE_SID=PROD
Num=`echo show user | $ORACLE_HOME/bin/sqlplus -s $SH_USERNAME/$SH_PASSWORD | grep -i 'USER ' | wc -l`
if [ $Num -gt 0 ]
        then
                ## ok - instance is up
               echo Instance $ORACLE_SID has been connected
        else
                ## inst is down
                echo $ORACLE_SID is down  
                count=`expr $count + 1 `
        fi
$SHELL

运行结果如下:
[oracle@oel1 ~]$ ksh settdb.sh PROD
Instance PROD has been connected

这可以作为一个初始化的操作,如果切换到其他数据库也很方便,
然后编写相应的shell 脚本,比如查看表空间的情况
脚本如下:
sqlplus -S ${SH_USERNAME}/${SH_PASSWORD}@${ORACLE_SID} << EOF
set echo off
set feedback off
set verify off
set linesize 150
set pages 30
set heading off  
REM clear screen         
COLUMN Tablespace FORMAT           A20 HEADING 'Tablespace|Name' JUSTIFY left
COLUMN Total_Size FORMAT        999,999 HEADING 'Total|Size(MB)'  JUSTIFY left
COLUMN Free_Space FORMAT         999,999 HEADING 'Free(MB)'
COLUMN Percentage FORMAT          90.0 HEADING '%|Used'     JUSTIFY left
COLUMN decode     FORMAT           A14 HEADING '(Space Gauge)'
COLUMN fragdec    FORMAT           A14 HEADING '(Frag Gauge)'
COLUMN percfrag   FORMAT          90.0 HEADING '%|Frag'          JUSTIFY left
COLUMN frags      FORMAT       999,999 HEADING 'Frags'
COLUMN bigchunk   FORMAT       999,999 HEADING 'Big|Chunk(MB)'   JUSTIFY left
COLUMN data_files FORMAT            99 HEADING 'Data|Files'      JUSTIFY left
set heading on

select free.tablespace_name Tablespace, tot.total Total_Size,
100 - ((free.free / tot.total) * 100) Percentage,
decode
((ceil(10-(free.free / tot.total) * 10)),
0,'| .......... |',
1,'| *......... |',
2,'| **........ |',
3,'| ***....... |',
4,'| ****...... |',
5,'| *****..... |',
6,'| ******.... |',
7,'| *******... |',
8,'| ********.. |',
9,'| *********. |',
10,'| !! DNGR !! |') decode,
free.free Free_Space, bigchunk, data_files, frags, percfrag,
decode ((ceil(percfrag / 10)) ,
0,'| .......... |',
1,'| *......... |',
2,'| **........ |',
3,'| ***....... |',
4,'| ****...... |',
5,'| *****..... |',
6,'| ******.... |',
7,'| *******... |',
8,'| ********.. |',
9,'| *********. |',
10,'| !! DNGR !! |') fragdec
from (select tablespace_name, ceil(sum(bytes) / 1048576) total, count(*) data_files
            from dba_data_files
            group by tablespace_name) tot,
     (select tablespace_name, ceil(sum(bytes) / 1048576) free,
            ceil(max(bytes) / 1048576) bigchunk, count(*)frags, 100 - (max(bytes) /sum(bytes)) * 100 percfrag
            from dba_free_space
            group by tablespace_name) free
where free.tablespace_name = tot.tablespace_name;
exit
EOF

运行结果如下:
Tablespace           Total    %                             Big       Data           %
Name                 Size(MB) Used  (Space Gauge)  Free(MB) Chunk(MB) Files    Frags Frag  (Frag Gauge)
-------------------- -------- ----- -------------- -------- --------- ----- -------- ----- --------------
TBS2                       20   0.0 | .......... |       20        20     1        1   0.0 | .......... |
SYSAUX                    325  19.1 | **........ |      263       263     1        1   0.0 | .......... |
TBS1                       55   5.5 | *......... |       52        29     3        3  44.2 | *****..... |
UNDOTBS                   200   6.0 | *......... |      188       185     1        5   1.5 | *......... |
USERS                     135  78.5 | ********.. |       29        28     2        3   3.6 | *......... |
TEST                       10   0.0 | .......... |       10        10     1        1   0.0 | .......... |
SYSTEM                    325  68.3 | *******... |      103       103     1        1   0.0 | .......... |
RCTS                      100   0.0 | .......... |      100       100     1        1   0.0 | .......... |



来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/23718752/viewspace-764433/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/23718752/viewspace-764433/

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值