sosi脚本改造

最近有一个应用需求,就是在一个shell脚本中,通过一些逻辑得到一系列表名,然后作为参数传给著名的sosi脚本,产出物是每张表对应的一个分析结果文件。

sosi原始脚本中对于接收表名是用类似如下的语法:
column TABLE_NAME heading "Tables owned by &Table_Owner" format a30 select table_name from dba_tables where owner=upper('&Table_Owner') order by 1
...
where owner = upper(nvl(
'&&Owner',user)) and table_name = upper('&&Table_name')
然后执行脚本,会在变量出现的每一处命令行提示用户进行输入。

现在我需要让shell脚本调用这个sosi,表名作为参数传入,不要人工干预,自动赋值。可以改为:
COLUMN 1 new_value Table_owner COLUMN 2 new_value Table_name select '&1' "1" from dual; select '&2' "2" from dual; ... where owner = upper('&&Table_owner') and table_name = upper('&&Table_name')
传入sosi的是两个参数,table_owner和table_name,脚本其余部分使用table_owner和table_name的时候会自动使用开始赋值的值,注意这块必须是”前面的定义值”。

另外,如果参数值是数值类型,则需要写为:

select &1 "1" from dual;
  • 1
save_snippets_01.png
  • 1

只有字符型,才需要扩上引号。

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

转载于:http://blog.itpub.net/7192724/viewspace-2125002/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值