oracle字符串载取及判断是否包含指定字符串

切割字符串,一般是不会通过数据库函数来处理的(大部分是查询出结果后通过代码处理的),但是也有特殊的情况;

比如:Oracle数据库有一张表Node,字段有:

ID:主键

parentID:父节点

STATID:查询编码

NAME:名称

STATNAME:查询名字

SCALE:父子级别

看的出,这是张存储父子结构关系的表,而STATID的左右就是把父子结构的关系拼接起来:比如,某记录为:

ID   parentID    STATID   NAME            STATNAME                 SCALE

01                1       华南             华南                      1

03      01        1s3      上海             华南s上海                2

05      03        1s3s5    浦东新区        华南s上海s浦东新区        3

很容易看的出三条记录的父子结构,而STATID就是把当前记录的所有父节点的ID,用's'连接起来;比如ID=05的记录是“浦东新区”,是第三级的节点,它的父节点即二级节点是ID=03的“上海”,而“上海”的父节点即一级节点是ID=01的“华南”,这时“浦东新区”的STATID 就是1s3s5   

以此表为例,分割STATID!

常用函数:substr和instr

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,为负值时表示从尾部开始算起,字符串排列位置不变

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

解释:string:源字符串

      subString:要查找的子字符串

      position:查找的开始位置

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

For example:

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

由上面两个函数就可以进行字符串的切割了!

比如SQL如下:

select n.ID,n.parentid,n.statid,n.name
   substr(n.statid,instr(n.statid,'s',1,2)+1,(instr(n.statid,'s',1,3)-instr  (n.statid,'s',1,2)-1)) market_id
   from node n

注意:上面查找的就是statid中所有三级节点的ID值

       所有,真实使用中一定注意,只有三级(包含三级)以上的节点才有market_id值

==========================================================================================================================

 

declare aa varchar2 := 'wkressssdfdf';

begin

if instr(aa,'s')>0 then

dbms_output.put_line('有s字符');

else dbms_output.put_line('没有s字符');

end if;

end;

你可能感兴趣的:(oracle)