搜索
首页数据库Oracleoracle的转义字符是什么

在oracle中的转义字符:1、单引号,用于引用字符串或对自身转义;2、双引号,用于将非法的格式符包装起来;3、“&”也就是and符号,用于接连两个转义自身;4、Escape,用于指定一个非特殊符号为转义符。

oracle的转义字符是什么

本教程操作环境:Windows10系统、Oracle 11g版、Dell G3电脑。

oracle的转义字符是什么

1、Oracle 特殊字符 转义

关键词:oracle    转义                                          

环境:oracle9i plsql

在plsql里边执行:

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

这条sql语句往数据库的pageurl字段放进去了一个url地址,但是执行的时候却并非那么理想,因为这其中有一个oracle的特殊字符,需要进行转义,那就是字符'&'.

怎么处理上例中的特殊字符?

两个办法:

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

        2) update userinfo setpageurl='myjsp?page=1'||chr(38)||'pagesize=10' where id='test'

其中||是连字符, chr(38)跟ASCII的字符转码是一致的。

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

2、oracle 中如何转义 特殊字符

问: 如何转义 下划线 _

select * from ng_values where name like 'lady_%'

jieguo 结果显示 lady_test,lady_test,lady1

正确结果应该是:lady_test,lady_test

不包括lady1

请各位给出转义方法,3ks

answer:

select ... from ... where ... like '/_%' escape '/';

3、

insert into t(col) values(chr(ascii('&'))) ;

(方法一)

例:插入特殊字元'&'

SQL> SHOW DEFINE
define "&" (hex 26) ? <--- DEFINE的default值是 ‘&’
SQL> SET DEFINE OFF
SQL> SHOW DEFINE
define OFF
SQL> INSERT INTO <table_name> VALUES (&#39;AT&T&#39;);

/

1 row created

(方法二)

SQL> SHOW ESCAPE
escape OFF <--- ESCAPE的default值是 OFF
SQL> SET ESCAPE ON
SQL> SHOW ESCAPE
escape "\" (hex 5c)
SQL> INSERT INTO temp_table VALUES (&#39;select * from emp where ename =\&1&#39;);

1 row created.

几个测试方法:

SELECT &#39;myjsp?page=1&pagesize=10&#39; FROM dual;
SELECT &#39;myjsp?page=1&pagesize=10&#39; FROM dual;
SQL>   create   table   a  (b   varchar2(10));  
Table   created  
SQL>   insert   into   a  values(&#39;_a&#39;);

1   row   inserted  

SQL>   select   B   from  A   where   instr(b,&#39;_a&#39;)>0;  
B  
----------  
_a  
select   B   from   A  where   b   like   &#39;%\_a%&#39;  escape   &#39;\&#39;

先启动转义符  

set   escape   on  

select   B   from   A  where   b   like   &#39;%\_a%&#39;  escape   &#39;\&#39;;
select   B   from   A  where   b   like   &#39;%\_a%&#39;  escape   &#39;\&#39;;

注意

在Oracle中双引号”不是转义字符,因此存储直接存储就可以了,不需要转义了。

oracle转义符有:

1,单引号

在ORACLE中单引号有两个作用:1)引用字符串;2)对自身转义。

引用字符串时,单引号是成对出现的;而对自身的转义,也必定是双数的,所以,一个sql语句中,单引号必定是成对的.

Select &#39;abc&#39; a,&#39;&#39; b, &#39;&#39;&#39;&#39; c, &#39; &#39;&#39; &#39; d From Dual;

复杂转义字符串可用连接符||拆分,便于理解。连接符号‘||’左右的单引号没有任何的关系,除非‘||’是作为字符串的一部分(这在动态SQL中很常见)。

Select &#39;name&#39; || &#39;&#39;&#39;&#39;&#39;&#39; a, &#39;name&#39;&#39;&#39;&#39;&#39; b From Dual;
Output:name&#39;&#39;  name&#39;&#39;

2,双引号

1)一般来说,字符串中的双引号仅仅被当作一个普通字符进行处理。

此时,双引号不需要成对出现:

Select &#39;hh24"小时""mi""分"""ss"秒"&#39; Results From Dual;
Output:hh24"小时""mi""分"""ss"秒"

2)当出现在to_char的格式字符串中时,双引号有特殊的作用,就是将非法的格式符包装起来,避免出现ORA-01821: date format not recognized错误。

也就是说,去掉双引号和其包含的字符后,剩下的应该是一个合法的格式串。

to_char在处理格式字符串时,会忽略双引号:

Select To_Char(Sysdate, 'hh24"小时"mi"分"ss"秒"') As "当前时间/时分秒"  From Dual;

Output:09小时05分08秒 --别名中也有此应用

格式串为'hh24"小时"mi"分"ss"秒"';

去掉双引号部分后,剩下的是'hh24miss',是一个合法的格式串。

不过即使真不知道双引号的这个用法,也可以这样来处理,虽然麻烦一点:

Select To_Char(Sysdate, 'hh24') || '小时' || To_Char(Sysdate, 'mi') || '分' || To_Char(Sysdate, 'ss') || '秒' As Result From Dual;

Output:09小时05分08秒

3,&(and符号)

用来识别/设置自定义变量,后需跟变量名;如需作为字符使用,需使用Chr(38),或者接连两个&&(转义自身)

Select Chr(38) a, &#39;Tom&&Jerry&#39; b, &#39;Gun &#39;&#39;N Roses&#39; c From Dual;
Output:&    Tom&Jerry    Gun &#39;N Roses

4, Escape(指定转义符)

指定一个非特殊符号为转义符,多用在通配符转义

Select Table_Name From User_Tables Where Table_Name Like &#39;TB=_%=_%&#39; Escape &#39;=&#39;;
Output:TB_STUDENT_SCORE--筛选以TB开头,中间有两个_的表名

推荐教程:《Oracle视频教程

以上是oracle的转义字符是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Oracle软件的角色:简化业务流程Oracle软件的角色:简化业务流程May 10, 2025 am 12:19 AM

Oracle软件通过数据库管理、ERP、CRM和数据分析功能简化业务流程。1)OracleERPCloud自动化财务、人力资源等流程;2)OracleCXCloud管理客户互动,提供个性化服务;3)OracleAnalyticsCloud支持数据分析和决策。

Oracle的软件套件:解释的产品和服务Oracle的软件套件:解释的产品和服务May 09, 2025 am 12:12 AM

Oracle的软件套件包括数据库管理、ERP、CRM等,帮助企业优化运营、提高效率、降低成本。1.OracleDatabase管理数据,2.OracleERPCloud处理财务、人力资源和供应链,3.使用OracleSCMCloud优化供应链管理,4.通过API和集成工具确保数据流动和一致性。

MySQL与Oracle:许可,功能和福利MySQL与Oracle:许可,功能和福利May 08, 2025 am 12:05 AM

MySQL和Oracle的主要区别在于许可证、功能和优势。1.许可证:MySQL提供GPL许可证,免费使用,Oracle采用专有许可证,价格昂贵。2.功能:MySQL功能简单,适合Web应用和中小型企业,Oracle功能强大,适合大规模数据和复杂业务。3.优势:MySQL开源免费,适合初创公司,Oracle性能可靠,适合大型企业。

MySQL与Oracle:选择右数据库系统MySQL与Oracle:选择右数据库系统May 07, 2025 am 12:09 AM

MySQL和Oracle在性能、成本和使用场景上有显着差异。 1)性能:Oracle在复杂查询和高并发环境下表现更好。 2)成本:MySQL开源,成本低,适合中小型项目;Oracle商业化,成本高,适用于大型企业。 3)使用场景:MySQL适用于Web应用和中小型企业,Oracle适合复杂的企业级应用。选择时需根据具体需求权衡。

Oracle软件:最大化效率和性能Oracle软件:最大化效率和性能May 06, 2025 am 12:07 AM

Oracle软件可以通过多种方法提升性能。1)优化SQL查询,减少数据传输量;2)适当管理索引,平衡查询速度和维护成本;3)合理配置内存,优化SGA和PGA;4)减少I/O操作,使用合适的存储设备。

甲骨文:企业软件和云计算甲骨文:企业软件和云计算May 05, 2025 am 12:01 AM

Oracle在企业软件和云计算领域如此重要是因为其全面的解决方案和强大的技术支持。1)Oracle提供从数据库管理到ERP的广泛产品线,2)其云计算服务如OracleCloudPlatform和Infrastructure帮助企业实现数字化转型,3)Oracle数据库的稳定性和性能以及云服务的无缝集成提升了企业效率。

MySQL与Oracle:数据库系统的比较分析MySQL与Oracle:数据库系统的比较分析May 04, 2025 am 12:13 AM

MySQL和Oracle各有优劣,选择时需综合考虑:1.MySQL适合轻量级、易用需求,适用于Web应用和中小型企业;2.Oracle适合功能强大、可靠性高需求,适用于大型企业和复杂业务系统。

MySQL与Oracle:了解许可和成本MySQL与Oracle:了解许可和成本May 03, 2025 am 12:19 AM

MySQL采用GPL和商业许可,适合小型和开源项目;Oracle采用商业许可,适合需要高性能的企业。MySQL的GPL许可免费,商业许可需付费;Oracle许可费用按处理器或用户计算,成本较高。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器