说明:substr,substrb均为字符串截取函数,都带有三个参数,第一个参数为所要截取的字符串,第二个参数为strart(索引均从1开始),第三个参数为length。
sql> select substr('今天是个好日子',3,5) from dual;@H_403_11@ ----------@H_403_11@ 是个好日子
sql> select substrb('今天是个好日子',0); background-color:inherit">@H_403_11@ -----@H_403_11@ 天是
结论是substr是按照字来算的,而substrb()是按照字节来算的。看下面的例子:
sql> select substr('abcdef',4) from dual;@H_403_11@ ----@H_403_11@ cdef
sql> select substrb('abcdef',4) from dual;@H_403_11@ ----@H_403_11@ cdef
分析:对于字母来说,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) from dual ----output:5
总结
如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。