Oracle 正则表达式实例详解
Oracle 正则表达式实例详解FORM开发中的按行拆分需求:拆分后的行要有规律,并按前后层次排序 需求分析如下: 现有行: 2 , 2.1 , 2.2 , 2.3 3 对 2 进行拆分得到的 结果应该是 2.4 (2.4 是通过 查看历史记录中以2 开头,有一位小数点,小数点后一位最大值,获得该最大值+1 ,得到既是新行的后缀,保证拆分是按照前后顺序递增的) 对 2.1 进行拆分得到的应该是 :2.1.4 首先要保证 每次拆分得到的下一行都是多一位小数点 对2.1 拆分 获取最大后缀 比较对象 时候 应该匹配前缀是2.1的 且只有两位小数点的 (排除前缀符合位数不符合的情况:2.1.1.1 ,2.1.1.2 ) 对3 进行拆分 没有历史记录是以 3开头的情况 这时候 就要重新 开始拆分:得到的应该是 3.1 这里的关键就是匹配历史记录进行比较,决定拆分后的最后一位的最大值 匹配的时候不能按照 数字的位数来判断,因为数字有可能是两位数,三位数,应该根据小数点来判断 匹配要使用到 正则表达式:与PHP、Python一样Oracle 的正则表达式函数也是 主要由四个函数实现:相似匹配,定位查找,获取匹配子字符串,替换匹配结果(最重要) (1)相似匹配: regexp_like()第一个参数:原字符串,第二个参数匹配模式,第三个参数匹配选项 第三个参数 匹配选项在这几个函数中都要相似作用(可选) 常用: i:大小写不敏感; c:大小写敏感; n:点号 . 不匹配换行符号; 匹配成功返回true 失败返回 false 我的使用: 模式中的符号说明:模式需要用一对双引号括起来 (2)定位查找字符位置:regexp_instr( )前面两个字段必输: selectstr,regexp_instr(str,'.' ) ind,默认从第一个字符开始查找,查找第一个.号,也可以匹配资格符合要求的字符串,写对匹配格式即可,不一定是单个字符 regexp_instr(str,'.',1,2) ind,从第1个字符开始,查找第二个.号所在的位置 regexp_instr(str,5,2) ind 从第五个字符开始,查找第二个.号的位置,注意最终查找到的字符和字符串的位置是相对于查找字符串的起始位置 fromtmp where id='instr'; STR IND IND IND 192.168.0.1 4 8 10 selectregexp_instr('192.168.0.1',level) ind,-- 点号. 所在的位置 regexp_instr('192.168.0.1','d',level) ind -- 每个数字的位置 fromdual connectbylevel <= 9 连续匹配目标字符串出现的第一次出现的位置,第二次出现的位置,直到第九次出现的位置 IND IND 4 1 我的案例: (3) 获取匹配子字符串:regexp_substr()regexp_substr(source_string,match_parameter) regexp_substr()在最初目的是根据字符串中某一个字符,分割字符串形成一个数组之类的 例如: 192.168.233.23 按点号"." 分组 最终结果有四个 :192 168 233 23 注意的是 pattern书写的格式不仅仅要用括号括起来,还要使用中括号括起来 我的案例: select str,regexp_substr(str,'[^,]+') str,]+',1) str,从第一位开始匹配,获得用逗号分隔字符串之后,第一个‘分割后的子串' regexp_substr(str,2) str,-- occurrence 第几个匹配组 regexp_substr(str,2,1) str -- position 从第几个字符开始匹配 fromtmp whereid='substr'; STR STR STR STR STR 123,234,345 123 123 234 23 (4) 替换匹配结果:regexp_replace()') str -- 将第一、第二捕获组交换位置,用尖括号标识出来 fromtmp whereid='replace'; STR STR STR --------------- --------------- --------------- (020)12345678 (GZ)12345678 (020)<456123>78 001517729C28 001517729C28 <517001>729C28感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! (编辑:商洛站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |