oracle 全局查找字符串,Oracle截取字符串和查找字符串

oracle 截取字符(substr),检索字符位置(instr) case when then else end语句使用 收藏

常用函数:substr和instr

1.SUBSTR(string,start_position,[length])    求子字符串,返回字符串

解释:string 元字符串

start_position   开始位置(从0开始)

length 可选项,子字符串的个数

For example:

substr("ABCDEFG", 0); //返回:ABCDEFG,截取所有字符

substr("ABCDEFG", 2); //返回:CDEFG,截取从C开始之后所有字符

substr("ABCDEFG", 0, 3); //返回:ABC,截取从A开始3个字符

substr("ABCDEFG", 0, 100); //返回:ABCDEFG,100虽然超出预处理的字符串最长度,但不会影响返回结果,系统按预处理字符串最大数量返回。

substr("ABCDEFG", 0, -3); //返回:EFG,注意参数-3,为负值时表示从尾部开始算起,字符串排列位置不变。

2.INSTR(string,subString,position,ocurrence)查找字符串位置

解释:string:源字符串

subString:要查找的子字符串

position:查找的开始位置

ocurrence:源字符串中第几次出现的子字符串

For example:

INSTR('CORPORATE FLOOR','OR', 3, 2)中,源字符串为'CORPORATE FLOOR', 目标字符串为'OR',起始位置为3,取第2个匹配项的位置;返回结果为 14 '

oracle中length()与lengthb()区别

oracle中length()与lengthb()区别

OracleSQL.oracle中length()与lengthb()区别

SQL> select length('阿猪') from dual;

LENGTH('阿猪')

--------------

2

SQL> select lengthb('阿猪') from dual;

LENGTHB('阿猪')

---------------

4

区别:length求得是字符长度,lengthb求得是字节长度。

----------------------------------------------------------------------------------------------------SQL> select sysdate from dual;

SYSDATE

--------------

26-9月 -05

SQL> select length(sysdate) from dual;

LENGTH(SYSDATE)

---------------

9

SQL> select lengthb(sysdate) from dual;

LENGTHB(SYSDATE)

----------------

10

length返回的是字符数

lengthb返回的是字节数

汉字“月”在length时,返回的时1

而在lengthb时返回的时2

length指的是字符个数,lengthb指的是字节数。字符个数跟数据库字符集有很大关系。length和lengthb的参数都为varchar2型,因此length(sysdate)有一个隐式的类型转换,实际上等同于length(to_char(sysdate)),ORACLE安装好后默认的NLS_DATE_FORMAT参数值为DD-MON-RR,结果就相当于length('28-9月 -05')和

lengthb('28-9月 -05')了,其结果就是9和10