分类 报考指南 报名.资讯 培训辅导 准考证.成绩 模拟试题 领证.注册.政策

replace和translate函数详解

 


 简要比较:

    replace:字符串级别的代替

    如:SELECT REPLACE('acdd','cd','ef') FROM dual; →aefd

    translate:字符级别的代替

    如:SELECT TRANSLATE('acdd','cd','ef') FROM dual; →aeff

    分别详解:

    replace:

    语法:REPLACE ( char , search_string [, replacement_string] )

    解释:repalce中,每个search_string都被replacement_string所代替。

    select replace('acdd','cd','ef') from dual;→ aefd

    如果replacement_string为空或为NULL,那么所有的search_string都被移除。

    select replace('acdd','cd','') from dual;→ad

    如果search_string为null,那么就返回原来的char。

    select replace('acdd','','ef') from dual;→acdd

    select replace('acdd','','') from dual;→acdd(也是两者都为空的情况)

    translate:

    语法:TRANSLATE ( 'char' , 'from_string' , 'to_string' )

    解释:Translate中,每个from_string中的字符被to_string中相应的字符所代替。

    select translate('acdd','cd','ef') from dual;→aeff

    如果from_string比to_string长,那么from_string中多余的字符将被移除。

    select translate('acdd','acd','ef') from dual;→ef (a由e代替,c由f代替,d就被移除)

    select translate('acdd','cda','ef') from dual;→eff(c由e代替,d由f代替,a就被移除)

    如果to_string为空,或者两者都为空,那么返回char也为空。所以to_string不能为空。

    select translate('acdd','cd','') from dual;→ (空)

    select translate('acdd','','') from dual;→(空)

    实战:

    如何判断一个字符串是否是数字?

    解:先转换:由于to_string不能为空,我们巧用#号代替

    select translate('abc123','#1234567890.','#') from dual;→abc

    from_string中的#被to_string中的#代替,但char中又没有#字符,所以通过这一步躲开了to_string必须不为空的规则。然后后面的数字以及小数点都转换为空,于是原来的字符串中只留下abc三个字符。

    转换好后,用nvl2判断即可:

    select nvl2(translate('abc123','#1234567890.','#'),'字符串','数字') from dual;→字符串

    nvl2的作用就是,NVL2 (expr1, expr2, expr3) ->expr1不为NULL,返回expr2;为NULL,返回expr3。这样我们就可以判断一个字符串是否是数字了!解毕!

 

 


   >>学课在线网课试听.报名        >>学课在线智能题库.模拟做题       >>直播课程       >>录播课程

课程名称
课程免费试听
课程名称
课程免费试听
课程名称
课程免费试听
初级会计师

一级建造师

执业药师

中级会计师

二级建造师

护士资格证

注册会计师

一级造价工程师

健康管理师

经济师考试

监理工程师

考研辅导课

银行从业

安全工程师

自考课程

基金从业

一级消防工程师

心理咨询师

企业人力资源管理师

法律职业资格考试

公共营养师

社会工作者

消防设施操作员

保育员

教师资格证

成人高考

育婴师

公务员培训

文职培训

英语四六级

计算机软考
养老护理员
税务师培训

房产经纪人
咨询工程师

其它课程>>



重要提醒!!内容中联系方式并非本站联系方式,报名咨询的学员请与下面最新联系方式联系我们咨询报名-以免损失!
>>长期招聘兼职招生代理人员,项目合作,团报优惠咨询,有意者请联系我们 >>咨询:13312524700(可加微信)。

昆明学历中心:◆咨询电话:0871-65385921、13312528471 赖老师、钱老师(微信报名:17787865775)点击这里给我发消息


云南地州中心:◆咨询电话:0871-65385921、17787865775 冯老师、 王老师(微信报名:17787865775)点击这里给我发消息


总部报名地址: ◆昆明市-五华区教场东路莲花财富中心10楼;网课试听:ke.xuekaocn.cn   点击这里立即咨询我们



地州分校:   大理分校   丽江分校   迪庆分校   怒江分校   红河分校   临沧分校   玉溪分校   文山分校   保山分校   德宏分校   昭通分校   普洱分校   版纳分校 【各地州学员请加老师微信咨询报名,电话(微信):133-1252-4700】;2021年云南省成人高考>>立即报名



职业技能考证:心理咨询师、健康管理师、茶艺师等更多>◆咨询电话:133 1252 4700(微信)点击这里咨询我们  

公考培训咨询:◆国考云南省考公务员/事业单位面授培训,咨询电话:133 1252 4700 (微信)点击这里立即咨询我们






温馨提示:因考试政策、内容不断变化与调整,学课在线网提供的以上信息仅供参考,如有异议,请考生以权威部门公布的内容为准!

免责声明:以上内容仅代表原创者观点,其内容未经本站证实,学课在线网对以上内容的真实性、完整性不作任何保证或承诺,转载目的在于传递更多信息,由此产生的后果与学课在线网无关;如以上转载内容不慎侵犯了您的权益,请联系我们QQ:1536696595,我们将会及时处理。




网友评论