set define off

工作中碰到一条set define off语句不知道何意,google一下,发现如下解释:http://tag.csdn.net/Article/014564c7-41af-459b-bfd5-56addeab9bdc.html

在plsql里边执行:update userinfo set pageurl='myjsp?page=1&pagesize=10' where id='test'这条sql语句往数据库的pageurl字段放进去了一个url地址,但是执行的时候却并非那么理想,因为这其中有一个oracle的特殊字符,需要进行转义,那就是字符'&'.怎么处理上例中的特殊字符?

3个办法:

1) update userinfo set pageurl='myjsp?page=1'||'&'||'pagesize=10' where id='test'

2) update userinfo set pageurl='myjsp?page=1'||chr(38)||'pagesize=10' where id='test'其中||是连字符, chr(38)跟ASCII的字符转码是一致的。

3)plsql中还可以set define off来关闭特殊字符,还可以用show define来查看有些特殊定义的字符。 Oracle中的转

 

1.SET DEFINE OFF 的用法;
(摘自:http://hi.baidu.com/wanghp/blog/item/50d8a901fa57e4061d9583c6.html)
在SQL*Plus中默认的"&"表示替代变量,也就是说,只要在命令中出现该符号,SQL*Plus就会要你输入替代值。这就意味着你无法将一个含有该符号的字符串输入数据库或赋给变量,如字符串“SQL&Plus”系统会理解为以“SQL”打头的字符串,它会提示你输入替代变量Plus的值,如果你输入ABC,则最终字符串转化为“SQLABC”。
set define off 则关闭该功能,“&”将作为普通字符,如上例,最终字符就为“SQL&Plus”
set define off关闭替代变量功能
set define on 开启替代变量功能
set define *  将默认替代变量标志符该为“*”(也可以设为其它字符)

2.COMMENT 是oracle关键字,不可作为字段。
用法可见:http://lfmalga.iteye.com/blog/98374

你可能感兴趣的:(oracle,sql,Blog,Google,ITeye)