oracle 函数大全 之 substr

本文详细介绍了 Oracle 数据库中 SUBSTR 函数的使用方法,包括如何通过指定起始位置和长度来截取字符串,以及如何处理负数索引的情况。此外,还对比了 SUBSTR 和 SUBSTRB 函数的区别,并提供了实际应用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

oracle的substr函数的用法
取得字符串中指定起始位置和长度的字符串   substr( string, start_position,
[ length ]
)
如:
     substr(
'This is a test', 6, 2)     would return 'is'

     substr(
'This is a test', 6)     would return 'is a test'
     substr(
'TechOnTheNet', -3, 3)     would return 'Net'
     substr(
'TechOnTheNet', -6, 3)     would return 'The'

select substr('Thisisatest', -4, 2) value from dual    结果是  te

select substr('emros',-3,1) value from dual      结果是 r

substr('abcde',-6) = null
substr('abcde',-5) = 'abcde'
substr('abcde',-4) = 'bcde'
substr('abcde',-3) = 'cde'
substr('abcde',-2) = 'de'
substr('abcde',-1) = 'e'
substr('abcde',-0) = 'abcde'

 

补充说明:

substr,substrb均为字符串截取函数,都带有三个参数,第一个参数为所要截取的字符串,第二个参数为strart(索引均从1开始),第三个参数为length。

看下面的例子:

SQL> select substr('abcdef',3,4) from dual;
----
cdef

SQL> select substrb('abcdef',3,4) from dual;
----
cdef

再看下面的例子:

SQL> select substr('今天是个好日子',3,5) from dual;
----------
是个好日子

SQL> select substrb('今天是个好日子',3,5) from dual;
-----
天是

结论是substr是按照字数来算的,而substrb()是按照字节来算的。

总结:对于字母来说,substr与substrb作用时一样的,但对于汉字来说,substr是按字数来取值,而substrb是按字节来取值,当所取长度为奇数时,则自动舍弃最后一位字节。

类似的还有,

length与lengthb 长度计算函数 

select length('你好') from dual         ----output:2

select lengthb('你好') from dual       ----output :4

instr与instrb 字符串查找函数 instr(原字符串,查的字符串,起始位置,第几个匹配) 返回字符串位置,找不到返回0 .

select instr('日日花前长病酒','花前',1,1) from dual     ----output:3

select instrb('日日花前长病酒','花前',1,1) from dual     ----output:5

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值