微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何将参数传递给sql脚本?

CREATE TABLE DMS_POP_WKLY_REFRESH_20100201 NOLOGGING ParaLLEL AS
SELECT wk.*,bbc.distance_km,NVL(bbc.tactical_broadband_offer,0) tactical_broadband_offer,sel.tactical_select_executive_flag,sel.agent_name,res.DMS_RESIGN_CAMPAIGN_CODE,pclub.tactical_select_flag
FROM   spineowner.pop_wkly_refresh_20100201 wk,dms_bb_coverage_102009 bbc,dms_select_executive_group sel,DMS_RESIGN_CAMPAIGN_26052009 res,DMS_PRIORITY_CLUB pclub
WHERE  wk.mpn = bbc.mpn(+)
AND    wk.mpn = sel.mpn (+)
AND    wk.mpn = res.mpn (+)
AND    wk.mpn = pclub.mpn (+)

vijay.sql(上面的sql脚本给出的名称)

如何在sql脚本中传递20100201的参数,我需要每次更改此日期格式.
如何通过传递date作为参数来调用sql脚本并在unix中运行它.这样就可以在每次运行中修改脚本中的日期

请帮帮我.

解决方法

sql * Plus使用& 1,& 2 …& n来访问参数.

假设您有以下脚本test.sql

SET SERVEROUTPUT ON
SPOOL test.log
EXEC dbms_output.put_line('&1 &2');
SPOOL off

你可以这样调用这个脚本,例如:

$sqlplus login/pw @test Hello World!

编辑:

在UNIX脚本中,您通常会调用这样的sql脚本:

sqlplus /nolog << EOF
connect user/password@db
@test.sql Hello World!
exit
EOF

这样你的登录名/密码就不会出现在另一个会话的ps上了

原文地址:https://www.jb51.cc/mssql/83405.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐