set define off(关闭默认字符转义)在数据库脚本中的作用

本文介绍了解决在使用SQL*Plus时遇到的因字符串中包含&符号而导致无法正常插入数据的问题。通过设置set define off,可以使得&被当作普通字符处理,从而实现数据的成功插入。

最近在使用ORACLE数据库插入数据的时候发现了一个问题,插入数据中包含“&”符号在PL sql中提示要输入代替的VALUE值。导致无法成功插入数据。经网上查找了下我问题解决了,做了简单的总结。

 

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

set define off 则关闭该功能,“&”将作为普通字符,如上例,最终字符就为“SQL&Plus”。

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

 

以上是说明,现在将使用sql plus连接数据库 用户名/密码@库名称 在执行 set define off. 就可以将.sql文件数据导入数据库,输入 @c:\xxx.sql 回车键

执行完毕后在输入 commit命令提交后才生效否则是无法查询插入的数据。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值