切割字符串,一般是不会通过数据库函数来处理的(大部分是查询出结果后通过代码处理的),但是也有特殊的情况;
比如:Oracle数据库有一张表Node,字段有:
ID:主键
parentID:父节点
STATID:查询编码
NAME:名称
STATNAME:查询名字
SCALE:父子级别
看的出,这是张存储父子结构关系的表,而STATID的左右就是把父子结构的关系拼接起来:比如,某记录为:
ID
01
03
05
很容易看的出三条记录的父子结构,而STATID就是把当前记录的所有父节点的ID,用's'连接起来;比如ID=05的记录是“浦东新区”,是第三级的节点,它的父节点即二级节点是ID=03的“上海”,而“上海”的父节点即一级节点是ID=01的“华南”,这时“浦东新区”的STATID 就是1s3s5
以此表为例,分割STATID!
常用函数:substr和instr
SUBSTR(string,start_position,[length])
解释:string 元字符串
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:源字符串
For example:
INSTR('CORPORATE FLOOR','OR', 3, 2)中,源字符串为'CORPORATE FLOOR', 目标字符串为'OR',起始位置为3,取第2个匹配项的位置;返回结果为 14
由上面两个函数就可以进行字符串的切割了!
比如SQL如下:
select n.ID,n.parentid,n.statid,n.name
注意:上面查找的就是statid中所有三级节点的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;