今天遇到一个问题,同事用动态sql生成的insert语句,其中含有&符号,在做insert时,这个&符号就被作为一个变量提示符了。如何解决这个问题?其实很简单:set define off
SQL>create
tablet
(avarchar2(20));
Table created.
SQL> insertinto tvalues('aaa&bbb');
Enter valuefor bbb: .
old 1:insert intot values('aaa&bbb')
new 1:insert intot values('aaa.')
1 rowcreated.
SQL> rollback;
Rollback complete.
SQL>
SQL>--wenow setdefine toOFF,theninsert data.
SQL> setdefine off
SQL> insertinto tvalues('aaa&bbb');
1 rowcreated.
SQL> select *from t;
A
--------------------
aaa&bbb
SQL>
Table created.
SQL> insertinto tvalues('aaa&bbb');
Enter valuefor bbb: .
old 1:insert intot values('aaa&bbb')
new 1:insert intot values('aaa.')
1 rowcreated.
SQL> rollback;
Rollback complete.
SQL>
SQL>--wenow setdefine toOFF,theninsert data.
SQL> setdefine off
SQL> insertinto tvalues('aaa&bbb');
1 rowcreated.
SQL> select *from t;
A
--------------------
aaa&bbb
SQL>
我们发现set define off后,带&符号的数据已经插入。
转自:http://blog.youkuaiyun.com/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