glogin.sql 修改sqlplus 提示符

vi  $ORACLE_HOME/sqlplus/admin/glogin.sql
 
最简单明了的提示符就是 USER@INSTANCE_NAME
 
-- Used by prompt
 
set termout off
 
define gname=idle   // 定义instance 没起的情况下使用的默认值//
 
COLUMN GLOBAL_NAME new_value gname
 
SELECT upper(USER) || '@' ||upper(instance_name)||'-'||HOST_NAME 
GLOBAL_NAME FROM v$instance;
 
set sqlprompt '&gname>'
 
set termout on
 
考虑到Dataguard 等多节点环境下,不同服务器有相同的 USER@INSTANCE_NAME
 
所以,需要再添加主机名判断条件,并设定提示符:
 
STD:standby
PRD:prod
NPE:none prod env.
 
-- Used by prompt
 
set termout off
 
define gname=idle    // 定义instance 没起的情况下使用的默认值//
 
COLUMN GLOBAL_NAME new_value gname
 
-- SELECT upper(USER) || '@' ||upper(instance_name)||'-'||HOST_NAME 
GLOBAL_NAME FROM v$instance;
SELECT upper(USER) || '@' ||upper(instance_name)|| '%' ||
DECODE
(host_name,'pd101','STB','pd102','STB','pd103','PRD','pd201','PRD','dfpd102','PRD','NPE') GLOBAL_NAME
FROM v$instance;
 
set sqlprompt '&gname >>'
 
set termout on
 
SYS@101_RP%NPE> select sysdate from dual;
SYSDATE
-------------------
2010-07-29 19:36:20
 
 
define gname=idle   // 定义instance 没起的情况下使用的默认值//  :
非常重要,因为当Instance没有起的时候,select 查询语句会报错,当执行到 set sqlprompt '&gname >>' 时,需要从前台接收变量的值。通常在交互模式下,这时会人为的输入回车。
然而,一些后台脚本或者第三方工具,如RMAN备份恢复脚本,在尝试连接idle的instance 时,由于没有人为的输入&gname 变量值,因而会报错,导致脚本执行失败。

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

转载于:http://blog.itpub.net/11976525/viewspace-669791/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值