最近有一个应用需求,就是在一个shell脚本中,通过一些逻辑得到一系列表名,然后作为参数传给著名的sosi脚本,产出物是每张表对应的一个分析结果文件。
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;
只有字符型,才需要扩上引号。