以下的文章主要介绍的是Oracle insert插入转义字符 ,单引号’与&符的相关问题,如果你觉得它们的名字很怪异,而且在实际的应用中也很少的涉及到它们的具体应用的话,以下的文章就是相关问题的解答。
今天在导入一批数据到Oracle时,碰到了一个问题:Toad提示要给一个自定义变量AMP赋值,一开始我很纳闷,数据是一系列的Insert语句,怎么会有自定义变量呢?后来搜索了一下关键字AMP发现,
Oracle把这里的URL的参数连接符&当成是一个自定义变量了,所以要求我给变量AMP赋值。怎么办呢?方法有三:
方法一:在要插入的SQL语句前加上Set define off;与原SQL语句一起批量执行
我们在SQL*PLUS下执行 SQL> show all命令时,可以发现一个参数:define “&” (hex 26),如下图所示
这个是Oracle insert插入转义字符里面用来识别自定义变量的设置,现在我们在SQL*PLUS下将其关闭:
然后再次执行导入脚本,OK!问题搞定。
注意:如果是在TOAD中执行,建议在每一个要导入的脚本***行加上前面那句关闭define的话,否则当你导入第二个含有特殊字符的脚本的时候,又会出错。
如果是在SQL*PLUS中执行,则只需要设置一次define OFF,后面就可以连续导入了。直到你重新设置define ON为止。
方法二:在SQL语句中将’&’替换成chr(38),因为chr(38)是‘&’的ASCII码
方法三:分拆原来的字符串
我们可以看到,方法一最为简便,而且效率也***。方法二因为有一个调用函数的过程,所以性能稍差。方法三需要两次连接字符串,效率最差!
那么如果字段的内容中包含了单引号要怎么插入呢?例如:It’s fine。方法同样有三
方法一:使用转义字符
注意:这里的””四个单引号是什么意思呢?首先***个和***一个都是Oracle insert插入转义字符中的字符串连接符,这个没有异议。那么第二个’和第三’又表示什么意思呢?第二个’是一个转义字符
第三个’才是我们真正的内容
方法二:同样是使用转义字符,只不过方式不同而已
注意:这里的第二个,第三个’就是我们上面方法一中提到的转义符和真正的内容
方法三:在SQL中将’替换成chr(39),因为chr(39)是’的ASCII码
【编辑推荐】

oracle9i变的很慢,基本都是对一张表的增删改的操作.
1、增大SGA中database buffer大小2、看看表空间、临时表空间、回滚段等的大小是否足够3、不要建太多的索引,因为索引与数据是同步维护的4、看看建表时的PCTUSED、PCTFREE等参数是否合适5、插入时加上指示器/*+append*/6、语句最好使用预解析,即带参数sql,减少数据库解析时间7、表上或列上不要建立太多约束8、查看锁状况,要及时提交数据修改
你的01-09月-89是字符型的数据,不是date类型,虽然写法一样,显示出来一样,但是现在输入的这个是char型或者是varchar2型的。 要用to_date转换一下,具体的用法自己查查,这样印象才能深刻。
SQL中identity后括号中的值是什么意思?
identity(m,n),表示的是初始值,n表示的是每次自动增加的值。 如果m和n的值都没有指定,默认为(1,1)。 要么同时指定m和n的值,要么m和n都不指定,不能只写其中一个值,不然会出错。 一、不指定m和n的值时,于 SQL Server 的语法举例:结果展示,按照默认(1,1)开始排列:二、指定m和n的值结果展示,按照发开需求排列:扩展资料:向identity字段插入数据。 【语法】set identity_insert 表名 on;insert into 表名(列名1,列名2,列名3,列名4) values (数据1,数据2,数据3,数据4);set identity_insert 表名 off;【实例代码】结果展示:注意:插入数据时必须得指定identity修饰的字段的名字。
发表评论