oracle切割字符串函数substr,instr

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

比如: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值

资料来源:http://hi.baidu.com/huahua035/blog/item/80a7cc128f69b8dbf7039ec3.html

posted @   kumat  阅读(2362)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示