前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >sosi脚本改造

sosi脚本改造

作者头像
bisal
发布2019-01-29 15:38:24
4480
发布2019-01-29 15:38:24
举报

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

sosi原始脚本中对于接收表名是用类似如下的语法:

代码语言:javascript
复制
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,表名作为参数传入,不要人工干预,自动赋值。可以改为:

代码语言:javascript
复制
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的时候会自动使用开始赋值的值,注意这块必须是”前面的定义值”。

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

代码语言:javascript
复制
select &1 "1" from dual;

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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016年09月14日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档