Oracle之set define off 关闭替代变量功能-yellowcong

set define off , 就是一个变量参数的替换。插入的数据的时候,如果带有替换,就需要我们自己去输入替换符(默认是&,我们也可以通过命令set define * 修改成*或则其他的)后面的数据,就是需要替换的类容。

在SQL*Plus中默认的”&”表示替代变量,也就是说,只要在命令中出现该符号,SQL*Plus就会要你输入替代值。这就意味着你无法将一个含有该符号的字符串输入数据库或赋给变量,如字符串“SQL&Plus”系统会理解为以“SQL”打头的字符串,它会提示你输入替代变量 Plus的值,如果你输入ABC,则最终字符串转化为“SQLABC”。
set define off 则关闭该功能,“&”将作为普通字符,如上例,最终字符就为“SQL&Plus”

-- 关闭替代变量功能
set define off 
-- 开启替代变量功能
set define on

--将默认替代变量(&)标志符改为“*”(也可以设为其它字符)  
set define * 

案例

--set define off 关闭替代变量功能。
--SQL*PLUS中默认的"&"表示替代变量,当写入&时,数据库会要求其替换成其它的值。如:
create table tab_test( col varchar2(9) );
-- 开启替换
set define on;

-- 插入数据
insert into tab_test values( 'SQL&PLUS' );
-- 提示输入字符串 替换掉PLUS
Enter value for plus: ABC
old   1: insert into tab_test values( 'SQL&PLUS' )
new   1: insert into tab_test values( 'SQLABC' )


-- 关闭替换
set define off;
-- 再次插入,就不会有提示了
insert into tab_test values( 'SQL&PLUS' );


--将替代字符,换为'*'。例:
set define * 

-- 插入默认替换负 & 不好使了
insert into tab_test values( 'SQL&PLUS' );

-- 输入我们新设定的 * 符号就好用了
insert into tab_test values( 'SQL*PLUS' );
Enter value for plus: ABC
old   1: insert into tab_test values( 'SQL*PLUS' )
new   1: insert into tab_test values( 'SQLABC' )

1 row created.

这里写图片描述

插入结果,大家会发现,插入的数据替换成了test
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

狂飙的yellowcong

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值