oracle特殊符合&的处理: set define off

今天遇到一个问题,同事用动态sql生成的insert语句,其中含有&符号,在做insert时,这个&符号就被作为一个变量提示符了。如何解决这个问题?其实很简单:set define off

SQL > create table t ( a varchar2 ( 20 )) ;
 
Table created .
 
SQL > insert into t values ( ' aaa&bbb ' ) ;       
Enter value for bbb : .
old     1 : insert into t values ( ' aaa&bbb ' )
new     1 : insert into t values ( ' aaa. ' )
 
1 row created .
 
 
SQL > rollback ;
 
Rollback complete .
 
SQL >
SQL >-- we now set define to OFF , then insert data .
SQL > set define off
SQL > insert into t values ( ' aaa&bbb ' ) ;
 
1 row created .
 
SQL > select * from t ;
 
A
------------------
--
aaa&bbb

 
SQL >

我们发现set define off后,带&符号的数据已经插入。


转自:http://blog.csdn.net/bupt_zoucq/article/details/6714101


set define off关闭替代变量功能 

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

set define off关闭替代变量功能 
set define on 开启替代变量功能 
set define *  将默认替代变量标志符该为“*”(也可以设为其它字符)


转自:http://zhidao.baidu.com/link?url=DQqFgsgF-p2GkjQb3bs_9v1PiPZYW_6ZnyhPRFTxgq59MONInUhzCRvx0U8Go1dfz1umjtgw9TtqCQW42rzEyq

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值