最近有一个应用需求,就是在一个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
- 1
只有字符型,才需要扩上引号。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7192724/viewspace-2125002/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/7192724/viewspace-2125002/