加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Oracle中SUBSTR与SUBSTRB的区别

发布时间:2020-12-12 16:18:09 所属栏目:百科 来源:网络整理
导读:说明:substr,substrb均为字符串截取函数,都带有三个参数,第一个参数为所要截取的字符串,第二个参数为strart(索引均从1开始),第三个参数为length。 SQL select substr('今天是个好日子',3,5) from dual; ---------- 是个好日子 SQL select substrb('今

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

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

SQL> select substrb('今天是个好日子',0); background-color:inherit">
-----
天是

结论是substr是按照字来算的,而substrb()是按照字节来算的。看下面的例子:

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

SQL> select substrb('abcdef',4) from dual;
----
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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读