oracle字符串载取及判断是否包含指定字符串
来源:互联网 发布:民法网络教育入学考试 编辑:程序博客网 时间:2024/06/05 19:53
切割字符串,一般是不会通过数据库函数来处理的(大部分是查询出结果后通过代码处理的),但是也有特殊的情况;
比如: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字符串载取及判断是否包含指定字符串
- oracle字符串载取及判断是否包含指定字符串
- 判断字符串是否包含指定的字符串
- ios 判断字符串是否包含指定字符串
- oracle判断字符串是否包含
- oracle判断字符串包含几个指定字符
- oracle判断是否包含字符串的方法
- oracle判断是否包含字符串的方法
- oracle判断是否包含字符串的方法
- oracle判断是否包含字符串的方法
- shell-判断指定文件中是否包含指定的字符串
- Oracle判断指定字符串拆分后是否包含另一个字符换
- oracle判断一个字符串中是否包含另外一个字符串
- oracle判断一个字符串中是否包含另外一个字符串
- oracle判断一个字符串中是否包含另外一个字符串
- Oracle判断一个字符串是否包含另一个字符串
- oracle判断一个字符串中是否包含另外一个字符串
- C# 判断指定字符串是否包含有汉字
- MSSQL2005差异备份拿shell (MSSQL2005 Backup Get Shell)
- 关于ftp.exe解决办法
- 计算机图形学国际知名期刊
- Failed to parse the output of 'adb version' 两种解决办法
- java.lang.OutOfMemoryError: PermGen space及其解决方法
- oracle字符串载取及判断是否包含指定字符串
- .globl的作用
- VMWare tools的安装过程及文件共享设置
- oerr 命令
- TreeView控件在IE7中连接线 对不齐
- VMware 5.5 Red Hat 9 屏幕分辨率调节详细方法
- QQTab切换特效
- CSS Float
- sql 语法 cast 不太清楚 还有ibatis语法