Welcome 微信登录

首页 / 数据库 / MySQL / 关于Oracle正则表达的使用

Oracle中的支持正则表达式的函数主要有下面四个:1,REGEXP_LIKE :与LIKE的功能相似  2,REGEXP_INSTR :与INSTR的功能相似  3,REGEXP_SUBSTR :与SUBSTR的功能相似  4,REGEXP_REPLACE :与REPLACE的功能相似  它们在用法上与Oracle SQL 函数LIKE、INSTR、SUBSTR 和REPLACE 用法相同,  但是它们使用POSIX 正则表达式代替了老的百分号(%)和通配符(_)字符。  POSIX 正则表达式由标准的元字符(metacharacters)所构成:  "^" 匹配输入字符串的开始位置,在方括号表达式中使用,此时它表示不接受该字符集合。  匹配输入字符串的结尾位置。如果设置了 RegExp 对象的 Multiline 属性,则 $ 也匹配 " " 或 " "。"." 匹配除换行符之外的任何单字符。"?" 匹配前面的子表达式零次或一次。"+" 匹配前面的子表达式一次或多次。"*" 匹配前面的子表达式零次或多次。"|" 指明两项之间的一个选择。例子"^([a-z]+|[0-9]+)表示所有小写字母或数字组合成的字符串。"( )" 标记一个子表达式的开始和结束位置。"[]" 标记一个中括号表达式。"{m,n}" 一个精确地出现次数范围,m=<出现次数<=n,"{m}"表示出现m次,"{m,}"表示至少出现m次。 um 匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。字符簇: [[:alpha:]] 任何字母。[[:digit:]] 任何数字。[[:alnum:]] 任何字母和数字。[[:space:]] 任何白字符。[[:upper:]] 任何大写字母。[[:lower:]] 任何小写字母。[[:punct:]] 任何标点符号。[[:xdigit:]] 任何16进制的数字,相当于[0-9a-fA-F]。各种操作符的运算优先级转义符(), (?:), (?=), [] 圆括号和方括号*, +, ?, {n}, {n,}, {n,m} 限定符^, $, anymetacharacter 位置和顺序| */
  1. select bcf.classify_code,bcf.classify_name ,bcf.hierarchy_code,length(REGEXP_REPLACE(bcf.hierarchy_code,"[0-9]",""))-1   
  2.  from base_classify bcf   
1 37 特色小店|3|37| 2
2 38 宠物|2|38| 2
3 40 便利店|3|40| 2
4 41 购物中心|3|41| 2
5 43 服装鞋帽|3|43| 2Oracle 分页 order by 问题Oracle date timestamp 毫秒 - 时间函数总结相关资讯      Oracle基础教程 
  • Oracle块编程返回结果集详解  (11/10/2013 10:45:58)
  • Oracle基础教程之设置系统全局区  (08/22/2013 14:24:00)
  • Oracle基础教程知识点总结  (06/18/2013 07:43:32)
  • Oracle基础教程之tkprof程序详解  (10/22/2013 11:49:50)
  • Oracle基础教程之sqlplus汉字乱码  (07/18/2013 16:30:00)
  • Oracle 管理之 Linux 网络基础  (02/16/2013 18:37:35)
本文评论 查看全部评论 (0)
表情: 姓名: 字数