Shell练习(4)_表的世代管理和存储过程
#!/bin/shnow=`date +"%Y%m%d %A %T"`echo "${now} /START AnalyzeTest">>D:/IDBCDB/test/tablechangeTest/TestMaster.log# 一時ファイルの指定spoolFile="D:/IDBCDB/test/AnalyzeTest/TablechangeTest.log"# DB接続情報の取得confFile="D:/IDBCDB/test/AnalyzeTest/oracon_newbiz.conf"userid=`grep '^userid' ${confFile} | cut -d= -f2`passwd=`grep '^passwd' ${confFile} | cut -d= -f2`constr=`grep '^constr' ${confFile} | cut -d= -f2`svaddr=`grep '^svaddr' ${confFile} | cut -d= -f2`port=`grep '^port' ${confFile} | cut -d= -f2`# DB接続テスト#CLASSPATH="${ORACLE_HOME}/jdbc/lib/classes12.zip;"#export CLASSPATHjava connectTest ${svaddr} ${port} ${constr} ${userid} ${passwd}echo $?if [ $? -ne 0 ];then exit 1fi# SQLの実行$ORACLE_HOME/bin/sqlplus -s ${userid}/${passwd}@${constr} << END > /dev/null 2>&1spool ${spoolFile}/* 前月テーブルを空にして、仮名称(今月テーブル用)に改名する(開発2部用)*/define num_out=0variable num_varnumbercol out_data new_value num_outDECLAREddl_cursor number;/* 内部????????*/PROCEDURE s_dbms_sql(t_nameINVARCHAR2)ISBEGIN/* 前月テーブルのTRUNCATE*/ddl_cursor := DBMS_SQL.OPEN_CURSOR;DBMS_SQL.PARSE(ddl_cursor,'truncate table P1_' || t_name,dbms_sql.v7);DBMS_SQL.CLOSE_CURSOR(ddl_cursor);/* 前月テーブルを仮名称に改名*/ddl_cursor := DBMS_SQL.OPEN_CURSOR;DBMS_SQL.PARSE(ddl_cursor,'rename P1_' || t_name || ' to TP_' || t_name,dbms_sql.v7);DBMS_SQL.CLOSE_CURSOR(ddl_cursor);:num_var := 0;END s_dbms_sql;BEGINs_dbms_sql('GUIMING_TABLE_20100312');EXCEPTIONWHEN OTHERS THEN DBMS_SQL.CLOSE_CURSOR(ddl_cursor);:num_var := 1;END;/select :num_var out_data from dual;exit num_outspool offENDif [ $? -ne 0 ];thenexit 1finow=`date +"%Y%m%d %A %T"`echo "${now} \END AnalyzeTest">>D:/IDBCDB/test/tablechangeTest/TestMaster.log#!/bin/shnow=`date +"%Y%m%d %A %T"`echo "${now} /START AnalyzeTest">>D:/IDBCDB/test/tablechangeTest/TestMaster.log# 一時ファイルの指定spoolFile="D:/IDBCDB/test/AnalyzeTest/TablechangeTest.log"# DB接続情報の取得confFile="D:/IDBCDB/test/AnalyzeTest/oracon_newbiz.conf"userid=`grep '^userid' ${confFile} | cut -d= -f2`passwd=`grep '^passwd' ${confFile} | cut -d= -f2`constr=`grep '^constr' ${confFile} | cut -d= -f2`svaddr=`grep '^svaddr' ${confFile} | cut -d= -f2`port=`grep '^port' ${confFile} | cut -d= -f2`# DB接続テスト#CLASSPATH="${ORACLE_HOME}/jdbc/lib/classes12.zip;"#export CLASSPATHjava connectTest ${svaddr} ${port} ${constr} ${userid} ${passwd}echo $?if [ $? -ne 0 ];then exit 1fi# SQLの実行$ORACLE_HOME/bin/sqlplus -s ${userid}/${passwd}@${constr} << END > /dev/null 2>&1spool ${spoolFile}/* 今月テーブルを前月テーブルに改名し、仮名称をつけたテーブルを今月テーブルに改名(開発2部用)*/define num_out=0variable num_varnumbercol out_data new_value num_outDECLAREddl_cursor number;/* 内部????????*/PROCEDURE s_dbms_sql(t_nameINVARCHAR2)ISBEGIN/* 今月テーブルを前月テーブルに改名*/ddl_cursor := DBMS_SQL.OPEN_CURSOR;DBMS_SQL.PARSE(ddl_cursor,'rename' || t_name || ' to P1_' || t_name,dbms_sql.v7);DBMS_SQL.CLOSE_CURSOR(ddl_cursor);/* 仮名称にしたテーブルを今月テーブルに改名*/ddl_cursor := DBMS_SQL.OPEN_CURSOR;DBMS_SQL.PARSE(ddl_cursor,'rename TP_' || t_name || ' to ' || t_name,dbms_sql.v7);DBMS_SQL.CLOSE_CURSOR(ddl_cursor);:num_var := 0;END s_dbms_sql;BEGINs_dbms_sql('GUIMING_TABLE_20100312');EXCEPTIONWHEN OTHERS THEN DBMS_SQL.CLOSE_CURSOR(ddl_cursor);:num_var := 1;END;/select :num_var out_data from dual;exit num_outspool offENDif [ $? -ne 0 ];thenexit 1finow=`date +"%Y%m%d %A %T"`echo "${now} \END AnalyzeTest">>D:/IDBCDB/test/tablechangeTest/TestMaster.log?
世代管理:
这是ETL里边一个很普遍的应用。
表分为前世代表,现世代表,后世代表。
现世代表主要是现在应用的表,前世代表主要是对现世代的以前数据的备份。
看第一个Shell将一个前世代表清空,然后改名为一个中间表。
第二个Shell把中间表改为现世代表,然后把现世代表更名为前世代表。
这样就完成了数据的备份。和清空现世代表,准备先一次数据的接收。
?
存储过程:
Shell中定义内部存储过程。
define num_out=0variable num_varnumbercol out_data new_value num_outDECLAREddl_cursor number;/* 内部????????*/PROCEDURE s_dbms_sql(t_nameINVARCHAR2)ISBEGIN/* 今月テーブルを前月テーブルに改名*/ddl_cursor := DBMS_SQL.OPEN_CURSOR;DBMS_SQL.PARSE(ddl_cursor,'rename' || t_name || ' to P1_' || t_name,dbms_sql.v7);DBMS_SQL.CLOSE_CURSOR(ddl_cursor);/* 仮名称にしたテーブルを今月テーブルに改名*/ddl_cursor := DBMS_SQL.OPEN_CURSOR;DBMS_SQL.PARSE(ddl_cursor,'rename TP_' || t_name || ' to ' || t_name,dbms_sql.v7);DBMS_SQL.CLOSE_CURSOR(ddl_cursor);:num_var := 0;END s_dbms_sql;BEGINs_dbms_sql('GUIMING_TABLE_20100312');EXCEPTIONWHEN OTHERS THEN DBMS_SQL.CLOSE_CURSOR(ddl_cursor);:num_var := 1;END;/select :num_var out_data from dual;exit num_outspool offEND?
有关DBMS_SQL应用说明:
?
PL/SQL中使用动态SQL编程?
?