Linux/Unix shell 調用 PL/SQL

來源:互聯網
上載者:User

    Linux/Unix 下除了調用SQL之外,調用PL/SQL也是DBA經常碰到的情形,下面主要通過一些樣本給出如何在shell下面來調用pl/sql。

    其它相關的參考:
        Linux/Unix shell 指令碼中調用SQL,RMAN指令碼 
        Linux/Unix shell sql 之間傳遞變數

1、將pl/sql代碼逐行輸入到臨時檔案robin@SZDB:~/dba_scripts/custom/bin> more shell_call_plsql.sh#/bin/bash# +--------------------------------------------+# + An example of calling plsql in Shell       + # + Usage:                                     +# +      ./shell_call_plsql.sh $ORACLE_SID     +# + Author: Robinson                           +                              # +--------------------------------------------+## ---------------------------------#  Define variable and  check SID# ---------------------------------if [ -f ~/.bash_profile ]; then    . ~/.bash_profilefiif test $# -lt 1        then echo You must pass a SID        exit fiORACLE_SID=$1; export ORACLE_SID# ---------------------------------#  Prepare plsql script# ---------------------------------echo "set serveroutput on size 1000000" > /tmp/plsql_scr.sqlecho "set feed off" >> /tmp/plsql_scr.sqlecho "declare" >> /tmp/plsql_scr.sqlecho "cursor c1 (param1 varchar2) is" >> /tmp/plsql_scr.sqlecho "select decode(substr(value, 1, 1), '?', param1 || substr(value, 2), value) dd" >> /tmp/plsql_scr.sqlecho "from v\$parameter where name = 'background_dump_dest';" >> /tmp/plsql_scr.sqlecho "v_value v\$parameter.value%type;" >> /tmp/plsql_scr.sqlecho "begin open c1 ('$ORACLE_HOME'); fetch c1 into v_value; close c1;" >> /tmp/plsql_scr.sqlecho "dbms_output.put_line(v_value);" >> /tmp/plsql_scr.sqlecho "end;" >> /tmp/plsql_scr.sqlecho "/" >> /tmp/plsql_scr.sql# --------------------------------#  Execute plsql script# --------------------------------if [ -s /tmp/plsql_scr.sql ]; then    echo -e "Running SQL script to find out bdump directory... \n"     $ORACLE_HOME/bin/sqlplus -s "/ as sysdba" > /tmp/plsql_scr_result.log << EOF    @/tmp/plsql_scr.sqlEOFfiecho " Check the reslut "echo "------------------------"cat /tmp/plsql_scr_result.logexit #上面的代碼是查詢指定Oracle SID 的dump路徑。#通過逐行逐行的方式將代碼添加到檔案以形成pl/sql代碼。#需要注意逸出字元的使用,對於parameter 的$符號,我們進行了轉義。robin@SZDB:~/dba_scripts/custom/bin> ./shell_call_plsql.sh CNBO1Running SQL script to find out bdump directory...  Check the reslut ------------------------/u02/database/CNBO1/bdump2、一次性輸入pl/sql代碼到臨時檔案robin@SZDB:~/dba_scripts/custom/bin> more shell_call_plsql_2.sh#/bin/bash# +--------------------------------------------+# + An example of calling plsql in Shell       + # + Usage:                                     +# +      ./shell_call_plsql_2.sh $ORACLE_SID     +# + Author: Robinson                           +                              # +--------------------------------------------+## ---------------------------------#  Define variable and  check SID# ---------------------------------if [ -f ~/.bash_profile ]; then    . ~/.bash_profilefiif test $# -lt 1        then echo You must pass a SID        exit fiORACLE_SID=$1; export ORACLE_SID# ---------------------------------#  Prepare plsql script# ---------------------------------echo "set serveroutput on size 1000000set feed offdeclare  cursor c1 (param1 varchar2) is    select decode(substr(value, 1, 1),'?' , param1 || substr(value, 2), value) dd    from v\$parameter where name = 'background_dump_dest';  v_value v\$parameter.value%type;begin  open c1 ('/users/oracle/OraHome10g');   fetch c1 into v_value; close c1;  dbms_output.put_line(v_value);end;/exit ">/tmp/plsql_scr.sql# --------------------------------#  Execute plsql script# --------------------------------if [ -s /tmp/plsql_scr.sql ]; then    echo -e "Running SQL script to find out bdump directory... \n"     $ORACLE_HOME/bin/sqlplus -s "/ as sysdba" @/tmp/plsql_scr.sql >/tmp/plsql_scr_result.log fiecho " Check the reslut "echo "------------------------"cat /tmp/plsql_scr_result.logexit # Author : Robinson Cheng# Blog   : http://blog.csdn.net/robinson_0612#上面的方法是一次性將代碼輸入到臨時檔案,好處是直接按照pl/sql的書寫方式來寫,代碼清晰,簡潔明了。robin@SZDB:~/dba_scripts/custom/bin> chmod u+x shell_call_plsql_2.shrobin@SZDB:~/dba_scripts/custom/bin> ./shell_call_plsql_2.sh CNBO1Running SQL script to find out bdump directory...  Check the reslut ------------------------/u02/database/CNBO1/bdump3、變種方案(使用sql替代pl/sql)robin@SZDB:~/dba_scripts/custom/bin> more shell_call_plsql_3.sh# -------------------------------#  Set environment here# ------------------------------if [ -f ~/.bash_profile ]; then    . ~/.bash_profilefiexport MAIL_DIR=/users/robin/dba_scripts/sendEmail-v1.56export MAIL_LIST='Robinson.chen@2GoTrade.com'export MAIL_FM='oracle@szdb.com'# -----------------------------------# Find bdump directory for database# -----------------------------------ORACLE_SID=$1;  export ORACLE_SIDDUMP_DIR=`sqlplus -S '/ as sysdba' << EOFset pagesize 0 feedback off verify off heading off echo offSELECT value FROM  v\\$parameter WHERE  name = 'background_dump_dest';exitEOF`if [ -z ${DUMP_DIR} ]; then    MAIL_SUB= "The bdump directory was not found for ${ORACLE_SID}"    $MAIL_DIR/sendEmail -u $MAIL_SUB -f $MAIL_FM -t $MAIL_LIST -m $MAIL_SUB    exitelse    echo ${DUMP_DIR}fiexit#注,上面的這個並不是調用pl/sql,而是使用了sql來完成相同的功能。如果sql能完成的功能,建議優先使用sql來完成。#也要注意的是此處的parameter使用了兩個轉義符。#同時將sql執行的返回結果直接賦予給shell變數robin@SZDB:~/dba_scripts/custom/bin> chmod u+x shell_call_plsql_3.shrobin@SZDB:~/dba_scripts/custom/bin> ./shell_call_plsql_3.sh CNBO1/u02/database/CNBO1/bdump  

更多參考

有關Oracle RAC請參考
     使用crs_setperm修改RAC資源的所有者及許可權
     使用crs_profile管理RAC資源設定檔
     RAC 資料庫的啟動與關閉
     再說 Oracle RAC services
     Services in Oracle Database 10g
     Migrate datbase from single instance to Oracle RAC
     Oracle RAC 串連到指定執行個體
     Oracle RAC 負載平衡測試(結合伺服器端與用戶端)
     Oracle RAC 伺服器端串連負載平衡(Load Balance)
     Oracle RAC 用戶端串連負載平衡(Load Balance)
     ORACLE RAC 下非預設連接埠監聽配置(listener.ora tnsnames.ora)
     ORACLE RAC 監聽配置 (listener.ora tnsnames.ora)
     配置 RAC 負載平衡與容錯移轉
     CRS-1006 , CRS-0215 故障一例 
     基於Linux (RHEL 5.5) 安裝Oracle 10g RAC
     使用 runcluvfy 校正Oracle RAC安裝環境

有關Oracle 網路設定相關基礎以及概念性的問題請參考:
     配置非預設連接埠的動態服務註冊
     配置sqlnet.ora限制IP訪問Oracle
     Oracle 監聽器日誌配置與管理
     設定 Oracle 監聽器密碼(LISTENER)
     配置ORACLE 用戶端串連到資料庫

有關基於使用者管理的備份和備份恢複的概念請參考
     Oracle 冷備份
     Oracle 熱備份
     Oracle 備份恢複概念
     Oracle 執行個體恢複
     Oracle 基於使用者管理恢複的處理
     SYSTEM 資料表空間管理及備份恢複
     SYSAUX資料表空間管理及恢複
     Oracle 基於備份控制檔案的恢複(unsing backup controlfile)

有關RMAN的備份恢複與管理請參考
     RMAN 概述及其體繫結構
     RMAN 配置、監控與管理
     RMAN 備份詳解
     RMAN 還原與恢複
     RMAN catalog 的建立和使用
     基於catalog 建立RMAN儲存指令碼
     基於catalog 的RMAN 備份與恢複
     RMAN 備份路徑困惑
     使用RMAN實現異機備份恢複(WIN平台)
     使用RMAN遷移檔案系統資料庫到ASM
     linux 下RMAN備份shell指令碼
     使用RMAN遷移資料庫到異機

有關ORACLE體繫結構請參考
     Oracle 資料表空間與資料檔案
     Oracle 密碼檔案
     Oracle 參數檔案
     Oracle 聯機重做記錄檔(ONLINE LOG FILE)
     Oracle 控制檔案(CONTROLFILE)
     Oracle 歸檔日誌
     Oracle 復原(ROLLBACK)和撤銷(UNDO)
     Oracle 資料庫執行個體啟動關閉過程
     Oracle 10g SGA 的自動化管理
     Oracle 執行個體和Oracle資料庫(Oracle體繫結構) 
 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.