`
DangDang0701
  • 浏览: 76921 次
  • 性别: Icon_minigender_2
  • 来自: 大连
社区版块
存档分类
最新评论

Shell练习(4)_表的世代管理和存储过程

阅读更多
#!/bin/sh

now=`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 CLASSPATH

java connectTest ${svaddr} ${port} ${constr} ${userid} ${passwd}

echo $?
if [ $? -ne 0 ];then
        exit 1
fi
# SQLの実行
$ORACLE_HOME/bin/sqlplus -s ${userid}/${passwd}@${constr}  << END > /dev/null 2>&1	

spool ${spoolFile}
/* 前月テーブルを空にして、仮名称(今月テーブル用)に改名する(開発2部用)	*/
define num_out=0
variable num_var	number
col out_data new_value num_out

DECLARE
		ddl_cursor number;

		/* 内部プロシージャ					*/
		PROCEDURE s_dbms_sql(t_name	IN	VARCHAR2)
		IS
		BEGIN
			/* 前月テーブルの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;

BEGIN

	s_dbms_sql('GUIMING_TABLE_20100312');
	
EXCEPTION
		WHEN OTHERS THEN 
			DBMS_SQL.CLOSE_CURSOR(ddl_cursor);
			:num_var := 1;
END;
/
select :num_var out_data from dual;
exit num_out

spool off

END

if [ $? -ne 0 ];then
	exit 1
fi

now=`date +"%Y%m%d %A %T"`
echo "${now}    \END   AnalyzeTest">>D:/IDBCDB/test/tablechangeTest/TestMaster.log
#!/bin/sh

now=`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 CLASSPATH

java connectTest ${svaddr} ${port} ${constr} ${userid} ${passwd}

echo $?
if [ $? -ne 0 ];then
        exit 1
fi
# SQLの実行
$ORACLE_HOME/bin/sqlplus -s ${userid}/${passwd}@${constr}  << END > /dev/null 2>&1	

spool ${spoolFile}
/* 今月テーブルを前月テーブルに改名し、仮名称をつけたテーブルを今月テーブルに改名(開発2部用)		*/
define num_out=0
variable num_var	number
col out_data new_value num_out

DECLARE
		ddl_cursor number;

		/* 内部プロシージャ						*/
		PROCEDURE s_dbms_sql(t_name	IN	VARCHAR2)
		IS
		BEGIN
			/* 今月テーブルを前月テーブルに改名		*/	
			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;

BEGIN
	s_dbms_sql('GUIMING_TABLE_20100312');
		
EXCEPTION
		WHEN OTHERS THEN 
			DBMS_SQL.CLOSE_CURSOR(ddl_cursor);
			:num_var := 1;
END;
/
select :num_var out_data from dual;
exit num_out

spool off

END

if [ $? -ne 0 ];then
	exit 1
fi

now=`date +"%Y%m%d %A %T"`
echo "${now}    \END   AnalyzeTest">>D:/IDBCDB/test/tablechangeTest/TestMaster.log

 

世代管理:

这是ETL里边一个很普遍的应用。

表分为前世代表,现世代表,后世代表。

现世代表主要是现在应用的表,前世代表主要是对现世代的以前数据的备份。

看第一个Shell将一个前世代表清空,然后改名为一个中间表。

第二个Shell把中间表改为现世代表,然后把现世代表更名为前世代表。

这样就完成了数据的备份。和清空现世代表,准备先一次数据的接收。

 

存储过程:

Shell中定义内部存储过程。

define num_out=0
variable num_var	number
col out_data new_value num_out

DECLARE
		ddl_cursor number;

		/* 内部プロシージャ						*/
		PROCEDURE s_dbms_sql(t_name	IN	VARCHAR2)
		IS
		BEGIN
			/* 今月テーブルを前月テーブルに改名		*/	
			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;

BEGIN
	s_dbms_sql('GUIMING_TABLE_20100312');
		
EXCEPTION
		WHEN OTHERS THEN 
			DBMS_SQL.CLOSE_CURSOR(ddl_cursor);
			:num_var := 1;
END;
/
select :num_var out_data from dual;
exit num_out

spool off

END

 

有关DBMS_SQL应用说明:

 

PL/SQL中使用动态SQL编程

在PL/SQL程序设计过程中,会遇到很多必须使用动态sql的地方,oracle系统所提供的DMBS_SQL包可以帮助你解决问题。
(一)介绍
DBMS_SQL系统包提供了很多函数及过程,现在简要阐述其中使用频率较高的几种:

function open_cursor:打开一个动态游标,并返回一个整型;

procedure close_cursor(c in out integer);关闭一个动态游标,参数为open_cursor所打开的游标;

procedure parse(c in integer, statement in varchar2, language_flag in integer):对动态游标所提供的sql语句进行解析,参数C表示游标,statement为sql语句,language-flag为解析sql语句所用oracle版本,一般有V6,V7跟native(在不明白所连database版本时,使用native);

procedure define_column(c in integer, position in integer, column any datatype, [column_size in integer]):定义动态游标所能得到的对应值,其中c为动态游标,positon为对应动态sql中的位置(从1开始),column为该值所对应的变量,可以为任何类型,column_size只有在column为定义长度的类型中使用如VARCHAR2,CHAR等(该过程有很多种情况,此处只对一般使用到的类型进行表述);

function execute(c in integer):执行游标,并返回处理一个整型,代表处理结果(对insert,delete,update才有意义,而对select语句而言可以忽略);

function fetch_rows(c in integer):对游标进行循环取数据,并返回一个整数,为0时表示已经取到游标末端;

procedure column_value(c in integer, position in integer, value):将所取得的游标数据赋值到相应的变量,c为游标,position为位置,value则为对应的变量;

procedure bind_variable(c in integer, name in varchar2, value):定义动态sql语句(DML)中所对应字段的值,c为游标,name为字段名称,value为字段的值;

以上是在程序中经常使用到的几个函数及过程,其他函数及过程请参照oracle所提供定义语句dbmssql.sql

(二)一般过程
对于一般的select操作,如果使用动态的sql语句则需要进行以下几个步骤:
open cursor--->parse--->define column--->excute--->fetch rows--->close cursor;
而对于dml操作(insert,update)则需要进行以下几个步骤:
open cursor--->parse--->bind variable--->execute--->close cursor;
对于delete操作只需要进行以下几个步骤:
open cursor--->parse--->execute--->close cursor;

 

 

分享到:
评论

相关推荐

    efi_shell_flash_bios-master.zip

    1. EFI Shell实用程序:这可能包括EFI Shell本身以及一系列用于BIOS管理和更新的命令行工具。 2. BIOS固件更新脚本:可能是一个或多个EFI可执行文件,设计用于更新系统的BIOS固件。 3. 指南或文档:可能包含如何...

    Linux_Commands and_Shell_Programming_2nd

    本文介绍的是一本关于Linux命令行操作和Shell编程的专业书籍。书名为《Linux Commands and Shell Programming 2nd》,即第二版《Linux命令及Shell编程实用指南》,作者为Mark G. Sobell。这本书被描述为Linux命令行...

    Shell_NotifyIcon_practice.rar

    在这个`Shell_NotifyIcon_practice.rar`压缩包中,包含了一个基于VS2017编写的C++窗口程序示例,用于演示如何使用`Shell_NotifyIcon()`来创建和管理这些图标。 `Shell_NotifyIcon()` 函数是一个关键的Windows API...

    Linux_Shell.rar_Linux shell_linux shell_linux_shell_shell_unix

    通过学习和实践Linux Shell,你可以更高效地管理和操作Linux系统,编写自动化脚本,甚至进行系统级的问题诊断。深入理解Shell,意味着你掌握了Linux世界的一个强大工具,为日常的工作和学习带来便利。

    shell_config.rar_Linux shell_parsing shell_shell config_get_sh

    在Linux系统中,Shell脚本是一种强大的自动化工具,它允许用户编写程序来执行一系列命令,进行文件操作,处理数据,甚至管理系统配置。标题"shell_config.rar_Linux shell_parsing shell_shell config_get_sh"暗示了...

    shell_priv_bear_shell_C2_

    在IT安全领域,"shell_priv_bear_shell_C2_"这个标题暗示了我们正在讨论一个与高级持续性威胁(APT)组织Fancy Bear相关的特权shell服务器和指挥与控制(C2)通道。Fancy Bear,也被称为APT28或Sofacy,是一个著名的...

    16shell脚本进阶_练习答案.zip

    16shell脚本进阶_练习答案。 1. 判断/var/目录下所有文件的类型 2. 添加10个用户user1-user10,密码为8位随机字符 3. /etc/rc.d/rc3.d目录下分别有多个以K开头和以S开头的文件;分别读取每个文件,以K开头的输出为...

    shell_ip_orangewgz_linux_shell_shell编程_shell脚本_

    在IT行业中,Shell编程是一种非常重要的技能,尤其是在Linux系统管理中。本文将深入探讨标题"shell_ip_orangewgz_linux_shell_shell编程_shell脚本_"所提及的利用Shell编写判断IP地址合法性的脚本这一主题。我们将...

    java_unix_shell.rar_java 模拟 shell_文件管理 java

    Unix Shell是Unix操作系统中的一个命令行接口,用户可以通过它来执行各种系统命令,进行文件管理和系统操作。Java作为一种跨平台的语言,非常适合用于这样的模拟项目,使得在非Unix环境下也能体验和学习Unix Shell的...

    基于Flask和Shell的pear_admin管理系统设计源码

    本源码提供了一个基于Flask和Shell的pear_admin管理系统设计。项目包含1194个文件,其中包括489个PNG图片、179个JavaScript文件、123个Python文件、90个CSS样式文件、81个HTML文件、77个GIF图片、38个SVG图像、24个...

    visual_studio_2010_shell_isolated_x86

    1、sqlserver 2012 因为卸载vs2010后无法正常使用,需要重新安装该插件

    jxta-shell-src-2.3.4.rar_JXTA Shell 2.5_r_java shell_jxta_jxta s

    JXTA Shell是JXTA框架的一部分,提供了一个命令行界面,用户可以通过它来执行各种JXTA相关的操作,如配置、管理和监控P2P网络。本文将深入探讨JXTA Shell 2.5_r的Java源码,帮助开发者更好地理解和利用这个强大的...

    XP_CMDSSQLSERVER扩展存储过程XP_CMDSHELL的简单应用

    XP_CMDSHELL存储过程是执行本机的CMD命令,要求系统登陆有SA权限,也就是说如果获得SQLSERVER的SA命令,那就可以在目标机为所欲为了,知名软件“流光”使用的应该也是这个存储过程来实现在目标机上的操作。

    shell shell练习 shell入门

    通过以上对Shell基础知识的学习和实际的练习,你将能够熟练地编写和运用Shell脚本来解决实际问题,提高在Linux或Unix环境下的工作效率。记得多实践,多尝试,理论与实践相结合,才能真正掌握Shell的魅力。

    shell_txt_to_csv

    4. 变量声明: 在 shell script 中声明变量,用于存储处理后的数据。 5. 条件语句: 使用 if 语句和 elif 语句对数据进行条件处理。 6. 字符串处理: 使用 cut 命令和 awk 命令对字符串进行处理,例如截取字符串、...

    Shell工具 SSH_Unix_Secure_

    SSH_Unix_Secure_Shell工具SSH_Unix_Secure_Shell工具SSH_Unix_Secure_Shell工具SSH_Unix_Secure_Shell工具SSH_Unix_Secure_Shell工具

    LINUX与UNIX SHELL编程指南_Linuxshell_linux_UNIX_

    通过深入学习这个"LINUX与UNIX SHELL编程指南",你将能够编写出高效、可读性强的Shell脚本,更好地管理和自动化Linux和Unix系统任务。这份指南将涵盖上述所有知识点,并可能提供实战案例和练习,以加深理解。阅读PDF...

    visual_studio_2010_integrated_shell_x86

    4. 集成的版本控制:与Team Foundation Server的紧密集成,使源代码管理变得轻松便捷,支持多种版本控制系统,如Git、SVN等。 5. 对.NET Framework 4的支持:Visual Studio 2010集成开发环境x86版本支持.NET ...

    k_shell.rar_K-shell_k-shell MATL_k-shell matlab_k_shell_matlab k

    根据k-shell算法,对网络进行划分,得到每一层的子网

    Linux_Shell_Scripting_with_Bash

    Linux Shell脚本编程是Linux系统管理、自动化任务和程序开发中的关键技能。Bash(Bourne-Again SHell)是Unix和Linux操作系统中最常用的Shell,它的强大功能和灵活性使得编写脚本变得简单而高效。本资料“Linux_...

Global site tag (gtag.js) - Google Analytics