oracle substr/instr/translate 函数使用介绍

[b]substr 函数:[/b]

    substr('This is a test', 6, 2) would return 'is'
substr('This is a test', 6) would return 'is a test'
substr('TechOnTheNet', 1, 4) would return 'Tech'
substr('TechOnTheNet', -3, 3) would return 'Net'
substr('TechOnTheNet', -6, 3) would return 'The'
substr('TechOnTheNet', -8, 2) would return 'On'


[b]instr 函数:[/b]

INSTR方法的格式为:
[b]INSTR(源字符串, 目标字符串, 起始位置, 匹配序号) [/b]
例如:
INSTR('CORPORATE FLOOR','OR', 3, 2)中,源字符串为'CORPORATE FLOOR', 目标字符串为'OR',起始位置为3,取第2个匹配项的位置。

默认查找顺序为从左到右。当起始位置为负数的时候,从右边开始查找。
所以SELECT INSTR('CORPORATE FLOOR', 'OR', -1, 1) "Instring" FROM DUAL的显示结果是
Instring
——————
14

select t.*, t.rowid from os_currentstep t where instr(t.owner,'wgc',-1,1)>0
在sql语句中可以判断这个字符串是否存在记录 判断出自己要筛选的记录

[b]translate 函数:[/b]

Translate主要是用来做字符串的替换的,对于字母和数字来说,是一个字符替换一个字符
如:
下面的语句会把 'f' 替换成 'v','a' 替换成 'g'
select Translate('fasdbfasegafs','fa','vg' ) value   from dual;

VALUE
-------------
vgsdbvgseggvs


但是对于汉字来说,则会根据不同的情况而有点不同

select Translate('fasdbfasegas','fa','我' ) value from dual;

VALUE
-----------
我sdb我segs


select Translate('fasdbfasegafs','fa','你' ) value from dual;

VALUE
-------------
你sdb你seg你s


第一个语句的fa替换成'我',由于最后面的a对应不到而用空代替
现在看第二个语句,前面的fa替换成了'你'没有问题,但是后面的af居然也是一样的替换?!

另外:
select Translate('fasdbfasegafs','fa','你我' ) value from dual;

VALUE
-------------------
你我sdb你我seg我你s

f被替换成'你'而a被替换成了'我'

可见oracle会根据替换字符串的不同而进行'自适应'

另外Translate还有一个小功能:
select trim(Translate('fasdbfa12vr2segas','abcdefghijklmnopqrstuvwxyz',' ')) value from dual;

VALUE
-----
122


最后综合使用:

update gd_stru_pole set name= substr(name,1,instr(translate(name,'1234567890','1111111111'),'1')-1)||'你要添加的字母'||substr(name,instr(translate(name,'1234567890','1111111111'),'1'))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值