我是靠谱客的博主 个性人生,这篇文章主要介绍oracle substr,substrb ,instr,instrb函数的用法以及like的优化,现在分享给大家,希望可以做个参考。

oracle substr,substrb ,instr,instrb函数的用法以及like的优化

 

--------------------substr,substrb----------------

 

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

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

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

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

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

SQL> select substrb('abcdef',3,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与Instrb 字符串查找函数 instr(原字符串,查的字符串,起始位置,第几个匹配) 返回字符串位置,找不到返回0 .

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

select instrb('日日花前长病酒','花前',1,1) from dual     ----output:5(在windows下pl/sql 9.5--oracle 9i测的结果为7)

----------------------nvl函数--------------------------

 

 如果你某个字段为空,但是你想让这个字段显示0
nvl(字段名,0),就是当你选出来的时候,这个字段虽然为空,但是显示的是0,当然这个0也可以换成其他东西,如:1,2,3……

 

----------------like 的优化方案-------------------------

 

 col like '%xxxx%'用instr(col,'XXXX')=0 替代

最后

以上就是个性人生最近收集整理的关于oracle substr,substrb ,instr,instrb函数的用法以及like的优化的全部内容,更多相关oracle内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(57)

评论列表共有 0 条评论

立即
投稿
返回
顶部