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
作者:唐小熊
出处:http://www.cnblogs.com/IT-Bear/
关于作者:一头写代码的熊
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接
如有问题,可以通过kumat@foxmail.com 联系我,非常感谢。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .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语句:使用策略模式优化代码结构