出处见文章底部。

/*

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 属性,则 $ 也匹

配 '\n' 或 '\r'。

'.' 匹配除换行符之外的任何单字符。

'?' 匹配前面的子表达式零次或一次。

'+' 匹配前面的子表达式一次或多次。

'*' 匹配前面的子表达式零次或多次。

'|' 指明两项之间的一个选择。例子'^([a-z]+|[0-9]+)$'表示所有小写字母或数字组合成的

字符串。

'( )' 标记一个子表达式的开始和结束位置。

'[]' 标记一个中括号表达式。

'{m,n}' 一个精确地出现次数范围,m=

出现m次。

\num 匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。

字符簇:

[[:alpha:]] 任何字母。

[[:digit:]] 任何数字。

[[:alnum:]] 任何字母和数字。

[[:space:]] 任何白字符。

[[:upper:]] 任何大写字母。

[[:lower:]] 任何小写字母。

[[:punct:]] 任何标点符号。

[[:xdigit:]] 任何16进制的数字,相当于[0-9a-fA-F]。

各种操作符的运算优先级

\转义符

(), (?:), (?=), [] 圆括号和方括号

*, +, ?, {n}, {n,}, {n,m} 限定符

^, $, anymetacharacter 位置和顺序

|

*/

--创建表

create table fzq

(

id varchar(4),

value varchar(10)

);

--数据插入

insert into fzq values

('1','1234560');

insert into fzq values

('2','1234560');

insert into fzq values

('3','1b3b560');

insert into fzq values

('4','abc');

insert into fzq values

('5','abcde');

insert into fzq values

('6','ADREasx');

insert into fzq values

('7','123 45');

insert into fzq values

('8','adc de');

insert into fzq values

('9','adc,.de');

insert into fzq values

('10','1B');

insert into fzq values

('10','abcbvbnb');

insert into fzq values

('11','11114560');

insert into fzq values

('11','11124560');

--regexp_like

--查询value中以1开头60结束的记录并且长度是7位

select * from fzq where value like '1____60';

select * from fzq where regexp_like(value,'1....60');

--查询value中以1开头60结束的记录并且长度是7位并且全部是数字的记录。

--使用like就不是很好实现了。

select * from fzq where regexp_like(value,'1[0-9]{4}60');

-- 也可以这样实现,使用字符集。

select * from fzq where regexp_like(value,'1[[:digit:]]{4}60');

-- 查询value中不是纯数字的记录

select * from fzq where not regexp_like(value,'^[[:digit:]]+$');

-- 查询value中不包含任何数字的记录。

select * from fzq where regexp_like(value,'^[^[:digit:]]+$');

--查询以12或者1b开头的记录.不区分大小写。

select * from fzq where regexp_like(value,'^1[2b]','i');

--查询以12或者1b开头的记录.区分大小写。

select * from fzq where regexp_like(value,'^1[2B]');

-- 查询数据中包含空白的记录。

select * from fzq where regexp_like(value,'[[:space:]]');

--查询所有包含小写字母或者数字的记录。

select * from fzq where regexp_like(value,'^([a-z]+|[0-9]+)$');

--查询任何包含标点符号的记录。

select * from fzq where regexp_like(value,'[[:punct:]]');

/*

理解它的语法就可以了。其它的函数用法类似。

*/

作者:唐山人,姓方,索性就叫tshfang。喜欢计算机,喜欢读书尤其是史书。技术共享,大家方便,让我们一起创造一个自由空间。

工作领域:ERP系统、计算机编程

oracle正则表达式非数字,oracle 判断是否数字 正则表达式法相关推荐

  1. 从控制台输入一个数字,判断这个数字是不是一个质数

    import java.util.Scanner; public class Three {// 从控制台输入一个数字,判断这个数字是不是一个质数public static void main(Str ...

  2. oracle 查找非中文,Oracle中如何判断一个字符串是否含有汉字

    看到网友问,怎么查询表中某个字段数据是不是包含了全角字符啊? 这个问题涉及到几个函数:to_single_byte.length和lengthb,我之前做开发的时候研究的是如何判断一个字符串中是否包含 ...

  3. 判断一个数字,判断这个数字是奇数还是偶数 打印出来

    public class homework1 {public static void main(String[] args) {java.util.Scanner input=new java.uti ...

  4. oracle 游标非空,oracle 游标判空步骤

    oracle 游标判空方法 create or replace package TAL_TEST is TYPE myCursorType IS REF CURSOR; --测试空游标 PROCEDU ...

  5. java 正则表达式 非贪婪模式_详解正则表达式的贪婪模式与非贪婪模式

    什么是正则表达式的贪婪与非贪婪匹配 如:String str="abcaxc"; Patter p="ab*c"; 贪婪匹配:正则表达式一般趋向于最大长度匹配, ...

  6. python 正则表达式 非贪婪,python中如何使用正则表达式的非贪婪模式示例

    前言 本文主要给大家介绍了关于python使用正则表达式的非贪婪模式的相关内容,分享出来供大家参考学习,下面话不多说了,来一起详细的介绍吧. 在正则表达式里,什么是正则表达式的贪婪与非贪婪匹配 如:S ...

  7. [java]判断一个数字中是否含有某个数字

    [java]判断一个数字中是否含有某个数字 例如判断一个数字中是否含有2 代码: public class panduan {public static boolean test(int n) {wh ...

  8. 正则表达式——非贪婪匹配

    在介绍非贪婪匹配前,我们先看一个简单的问题: 给定一个字符串表示的数字,判断该数字末尾0的个数.例如: "123000":3个0 "10100":2个0 &qu ...

  9. oracle正则判断数字开头,oracle 正则表达式判断是否数字

    oracle 正则表达式判断是否数字 发布时间:2018-12-13 10:35, 浏览次数:375 , 标签: oracle 正则表达式 ORACLE中的支持正则表达式的函数主要有下面四个: 1,R ...

  10. oracle排序非英文最后,Oracle中中文、数字,英文混杂形式的字段进行排序的方法...

    http://blog.csdn.net/p451933505/article/details/9272257 对Oracle中中文.数字.英文混杂形式的字段进行排序的方法: 例如: order by ...

最新文章

  1. 为什么MySQL不推荐使用uuid或者雪花id作为主键?
  2. aes离线解密工具_CTF常用工具、网站、练习平台
  3. hadoop 9000端口的服务未启动_IDEA 微服务单项目多端口启动
  4. 使ALV控件中的内容可编辑
  5. 【APP接口开发】常用HTTP响应头状态码详解
  6. C#语法——await与async的正确打开方式
  7. Linux (Ubuntu) 命令
  8. Java的几种路径总结
  9. 拓端tecdat|用于NLP的Python:使用Keras进行深度学习文本生成
  10. Kotlin的一点学习资源
  11. 企业BI项目蓝图规划建设方案
  12. limesurvey php5.2,如何在Limesurvey Docker映像上安装php composer
  13. 二元函数连续性、可导性及极限
  14. 网站建设-网站设计怎么样做的更好?
  15. nltk安装出错,nltk_data语料库下载
  16. Linux禅道安装步骤以及测试初认知
  17. NEO改进协议提案9(NEP-9)
  18. [职场、征人、面试]新技术能解决多少问题?....没有标准答案的个人感言
  19. 微信史诗级更新:60秒长语音有救了!
  20. Linux账号管理和ACL

热门文章

  1. python 并发之asyncio
  2. 马科维茨投资组合理论总结
  3. 如何在python同一行内输入若干个数?
  4. android设置闹钟组件,Android 设置系统闹钟
  5. 2009年全国数模比赛,江苏三等奖名单
  6. ASP.NET Word转换成PDF文件
  7. 疫情常态下的医院信息化建设新思考
  8. thinkphp 页面上循环checkbox选择的值和radio混用,if判断
  9. 计算机二级的图片尺寸,2021计算机二级照片是几寸 大小千万要记住咯
  10. 射频电路习题解答(一)——利用电子smith图解题