Oracle中插入特殊字符:&和'的解决方法汇总


今天在导入一批数据到Oracle时,碰到了这样一个问题:Toad提示要给一个自定义变量AMP赋值,一开始我很纳闷,数据是一系列的Insert语句,怎么会有自定义变量呢?后来搜索了一下关键字AMP发现,原来是因为在插入数据中有一个字段的内容如下:

http://xxx.com/3DX?uid=0676&sid=rt_060908

Oracle把这里的URL的参数连接符&当成是一个自定义变量了,所以要求我给变量AMP赋值。经过测试之后,总结出以下三种方法:

方法一:在要插入的SQL语句前加上Set define off;与原SQL语句一起批量执行

我们在SQL*PLUS下执行 SQL> show all命令时,可以发现一个参数:define "&" (hex 26),代码如下所示

......
concat "." (hex 2e)
copycommit 0
copytypecheck ON
define "&" (hex 26)
describe DEPTH 1 LINENUM OFF INDENT OFF
echo OFF
......

这个是Oracle里面用来识别自定义变量的设置,现在我们在SQL*PLUS下将其关闭:

SQL> Set define OFF;

然后再次执行导入脚本,OK!问题搞定。

注意:如果是在TOAD中执行,建议在每一个要导入的脚本第一行加上前面那句关闭define的话,否则当你导入第二个含有特殊字符的脚本的时候,又会出错。
如果是在SQL*PLUS中执行,则只需要设置一次define OFF,后面就可以连续导入了。直到你重新设置define ON为止。

插入一条语句:

SQL> insert into AA (O,resvalue) values ('AA', 'S'||chr(38)||'P');

方法二:在SQL语句中将'&'替换成chr(38),因为chr(38)是‘&'的ASCII码

SQL> Select 'Tom' || chr(38) || 'Jerry' from dual;

方法三:分拆原来的字符串

SQL> Select 'Tom' || '&' || 'Jerry' from dual;

我们可以看到,方法一最为简便,而且效率也最高。方法二因为有一个调用函数的过程,所以性能稍差。方法三需要两次连接字符串,效率最差!

那么如果字段的内容中包含了单引号要怎么插入呢?例如:It's fine。这种情况下同样有三种方法:

方法一:使用转义字符

SQL > Select 'test' || '''' from dual;

注意:这里的''''四个单引号是什么意思呢?首先第一个和最后一个都是Oracle中的字符串连接符,这个没有异议。那么第二个'和第三'又表示什么意思呢?第二个'是一个转义字符
第三个'才是我们真正的内容

方法二:同样是使用转义字符,只不过方式不同而已

SQL > Select 'test ''' from dual;

注意:这里的第二个,第三个'就是我们上面方法一中提到的转义符和真正的内容

方法三:在SQL中将'替换成chr(39),因为chr(39)是'的ASCII码

SQL > Select 'It' || chr(39) || 'fine' from dual;



相关阅读:
C#中foreach语句使用break暂停遍历的方法
Mac itunes备份的文件在哪里 Mac itunes备份文件路径解析
jQuery使用CSS()方法给指定元素同时设置多个样式
让Mac屏幕横向或翻转显示适合躺在床上看电子书
php绘图之加载外部图片的方法
js实现数组冒泡排序、快速排序原理
PHP中的一些常用函数收集
使用生成系统健康报告快速查看Win8系统是否健康
Ubuntu Update-rc.d命令详细介绍
谈一谈Android内存泄漏问题
jQuery中:file选择器用法实例
PHP数组与对象之间使用递归实现转换的方法
在Ubuntu 15.10系统上安装NVIDIA 358.16显卡驱动
jQuery实现返回顶部功能适合不支持js的浏览器
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 CMS SQL jQuery C# C++ java Android IOS oracle MongoDB PostgreSQL SQLite 交通频道 贺州-仪征 克拉玛依-六安 鄂尔多斯-晋中 普兰店-日喀则 崇左-安宁 府谷-铜陵 雅安-丹阳 吉安-崇左 玉环-宜春 莱芜-攀枝花 常熟-垦利 三亚-中卫 临汾-宁波 鞍山-孝感 苏州-吴忠 合肥-荣成 广安-鄂州 江都-佳木斯 蚌埠-中卫 临沂-珠海 肇庆-贵阳 巩义-仙桃 中卫-乌海 普兰店-临沧 文山-宿州 通化-蚌埠 庄河-济宁 驻马店-瑞安 新昌-偃师 辽阳-张家界 邯郸-徐州 克拉玛依-德清 晋江-赤峰 雅安-九江 通辽-青州 德州-铜仁 遵义-固原 哈密-云浮 太仓-鹤岗 玉环-常德 宜兴-福州 宜都-菏泽 惠安-漯河 大理-烟台 茂名-常德 北京-衢州 宁波-安宁 衢州-都江堰 信阳-崇左 百色-广安 莱西-东阳 南平-南昌 南宁-六安 福清-永康 盐城-赤峰 崇明-大庆 即墨-固原 海北-铜川 宜宾-黄石 马鞍山-松原 克拉玛依-昌吉 四平-常州 孝感-玉溪 常熟-株洲 漳州-如东 深圳-锡林浩特 平顶山-海城 莱芜-遵义 廊坊-库尔勒 大石桥-武威 昌吉-东营 濮阳-青州 抚顺-盘锦 双鸭山-汕尾 东台-厦门 滨州-滕州 呼和浩特-汕尾 桂林-庆阳 宝鸡-丹东 惠州-遵义 甘谷-韩城 庐江-潢川 富裕-北安 齐齐哈尔-禹城 海石湾-商城 邯郸-德清西 三门峡南-郴州西 鹰潭-道州 加南-九三 清水-重庆 加格达奇-香坊 海城西-青田 略阳-宿州 双城堡-达州 呼和浩特东-锡林呼都嘎 遂宁-葫芦岛 济宁-麻城 武山-桐柏 绥化-浠水 芜湖-兰州 达州-河津 安仁-昆明 赤峰-巨宝 六地沟-公主埂 平顶庙-正镶白旗 北京-静海 龙骨甸-花棚子 长寿北-六安 清涧县-常州 包头东-清涧县 蚌埠-玉门 平顶庙-宇宙地 新立镇-姚家 静海-南阳 城子坦-沈阳 松江-湘乡 哈尔巴岭-老爷岭 南京南-合肥 绥中-清河城 江桥-灯塔 黑水-瓦房店 正定-下花园 济南-日照 连云港东-邳州 冷水江东-嘉善 苏家屯-营口 河源-绩溪县 长春-查布嘎 咸阳-济南 威海-高密 天津西-巢湖东 庐江-桐城 卓资东-林西 六地沟-哲里木 南宁东-溧阳 兰考-渑池 涿州-瑞昌 黄石-合川 江源-二岔 九台-朝阳镇 赵城-包头东 运城-宁武 阜宁-民权 惠州-峡江 海口东-临高南 伊宁-咸阳 渑池-洛阳 公主岭-中卫 庐江-惠州 河唇-柳州 高密-宿州东 东淤地-忻州 高头-鹤山 白彦花-乌海西 中寨-罗平 汉口-深圳北 富源-永川 祁县-天津 辽源-通辽 上海南-始兴

Copyright © 2016 phpStudy |