MySql正则表达式简介及使用

by:授客 QQ1033553122

简介

正则表达式描述了一组字符串,该字符放置于REGEXP工具后面。作用是将一个正则表达式与一个文本串进行比较。

最简单的正则表达式是不含任何特殊字符的正则表达式。

例如,正则表达式hello匹配hello。

非普通的正则表达式采用了特殊的特定结构,从而使得它们能够与1个以上的字符串匹配。

例如,正则表达式hello|word匹配字符串hello或字符串word。

实例

#正则表达式^,查找以指定字符串开头的语句

#eg:找出以start字符串开头的语句

select 'start' regexp '^start'; #结果 1 表示匹配到

SELECT 'start\nsrart' REGEXP '^srart$'; #结果0 表示没匹配到

#正则表达式$,查找以指定字符串结尾的语句

#eg:找出以end字符串结尾的语句

select 'wordsend' regexp 'end$'; #结果 1 表示匹配到

select 'wordsend\r' regexp 'end$'; #结果 0 表示没匹配到

#正则表达式*

注意:单独一个*是非法的,要看*前面的符号,如果是 . 就可以匹配任意字符(包括回车和新行)

#eg:匹配任意字符,以新行(\n)或回车(\r)结尾

select 'anbny\n' regexp '^a.*$'; #结果 1 表示匹配到

select 'anfyn\r' regexp '^a.*$'; #结果 1 表示匹配到

#正则表达式x*x为任意字符,查找包含0或多个x字符的语句

#eg:查找包含0或多个a字符的语句

select 'andkdkd' regexp 'a*'; #结果 1 表示匹配到

select 'aaaaaaadkdkd' regexp 'a*'; #结果 1 表示匹配到

select 'nmnnkdkd' regexp 'a*'; #结果 1 表示匹配到

#正则表达式x+x为任意字符,查找包含至少一个x字符的语句

#eg:查找包含至少一个a字符的语句

select 'akkdkdkd' regexp 'a+'; #结果 1 表示匹配到

select 'aaaaakdkdkdk' regexp 'a+'; #结果 1 表示匹配到

select 'kdkdkdld' regexp 'a+'; #结果 0 表示没匹配到

#正则表达式x?,x为任意字符,查找包含一个或0X字符的语句

select 'akdkdkdk' regexp 'a?'; #结果 1 表示匹配到

select 'kdkdkdkdk' regexp 'a?'; #结果 1 表示匹配到0个

select 'kaakkk' regexp '^ka?k'; #结果 0 应该匹配kak或kk

#正则表达式 字符串1|字符串2,查找包含字符串1或字符串2的语句,注意|前后不要有空格

select 'xxa' regexp 'xxa|pkdkd'; #结果 1 表示匹配到

select 'pkdkd' regexp 'xxa|pkdkd'; #结果 1 表示匹配到

select 'xxapkdkd' regexp 'xxa|pkdkd'; #结果 1 表示匹配到

select 'xxdkd' regexp 'xxa|pkdkd';  #结果 0 表示无匹配到

#正则表达式 (abc)*,查找包含任意多个abc语句(包括空串)

#eg

select 'axkd' regexp '(xk)*'; #结果1 表示匹配到

select 'akd' regexp '(xd)*'; #结果1 匹配到0个

select 'xdxd' regexp '(xd)*'; #结果是1

#正则表达式 {n}{m,n}mn均为整数

#a*可以写成 a{0,} a+可以写成a{1,} a?可被写入为a{0,1}

#更准确地讲,a{n}与a的n个实例准确匹配。a{n,}匹配a的n个或更多实例。a{m,n}匹配a的m~n个实例,包含m和n。

#m和n必须位于0~RE_DUP_MAX(默认为255)的范围内,包含0和RE_DUP_MAX。如果同时给定了m和n,m必须小于或等于n。

#eg:

SELECT 'abcde' REGEXP 'a[bcd]{2}e'; #结果为0 abe ace ade 不能满足

SELECT 'abcde' REGEXP 'a[bcd]{1}e'; #结果为0 同上

SELECT 'abcde' REGEXP 'abcd{1}e'; #结果为1 abcd 匹配到一个

SELECT 'abcde' regexp 'ab{1,}'; #结果为1 ab 匹配到一个

SELECT 'abcde' regexp 'ab{2,}'; #结果为0 ab 只匹配到一个,不能满足2

SELECT 'abcde' regexp 'a[bcd]{1,10}e'; #结果为1  ?好晕,不清楚啥情况

SELECT 'abcde' regexp 'a[bcd]{3,10}e'; #结果为1  ?好晕,不清楚啥情况

SELECT 'abcde' regexp 'a[bcd]{4,10}e'; #结果为0  ?好晕,不清楚啥情况

#正则表达式[a-dX], [^a-dX]

#匹配任何是(或不是,如果使用^的话)a、b、c、d或X的字符。

#两个其他字符之间的“-”字符构成一个范围,与从第1个字符开始到第2个字符之间的所有字符匹配。

#例如,[0-9]匹配任何十进制数字。要想包含文字字符“]”,它必须紧跟在开括号“[”之后。要想包含文字字符“-”,

#它必须首先或最后写入。对于[]对内未定义任何特殊含义的任何字符,仅与其本身匹配。

#eg:

SELECT 'aXbc' regexp '[a-dXYZ]'; #结果是1

SELECT 'aXbc' REGEXP '^[a-dXYZ]$'; #结果是0

SELECT 'aXbc' REGEXP '^[a-dXYZ]+$';#结果是1

SELECT 'aXbc' REGEXP '^[^a-dXYZ]+$'; #结果是0

SELECT 'gheis' REGEXP '^[^a-dXYZ]+$'; #结果是1

SELECT 'gheisa' REGEXP '^[^a-dXYZ]+$'; #结果是0

#正则表达式[.characters.]

#在括号表达式中(使用[.]),匹配用于校对元素的字符序列。字符为单个字符或诸如新行等字符名。在文件regexp/cname.h中,可找到字符名称的完整列表。

SELECT '~' REGEXP '[[.~.]]'; #结果是1

SELECT '~' REGEXP '[.~.]'; #结果是1

SELECT '~' REGEXP '[[.tilde.]]';  #结果是1  ??

SELECT '~' REGEXP '[[.titlde.]]'; #结果是0

#正则表达式[=character_class=]

#在括号表达式中(使用[和]),[=character_class=]表示等同类。它与具有相同校对值的所有字符匹配,包括它本身,

#例如,如果o和(+)均是等同类的成员,那么[[=o=]]、[[=(+)=]]和[o(+)]是同义词。等同类不得用作范围的端点。

#正则表达式 [:character_class:],在括号表达式中(使用[和]),[:character_class:]表示与术语类的所有字符匹配的字符类。标准的类名称是

# alnum  文字数字字符

# alpha  文字字符

# blank  空白字符

# cntrl  控制字符

# digit  数字字符

# graph  图形字符

# lower  小写文字字符

# print  图形或空格字符

# punct  标点字符

# space  空格、制表符、新行、和回车

# upper  大写文字字符

# xdigit 十六进制数字字符

#它们代表在ctype(3)手册页面中定义的字符类。特定地区可能会提供其他类名。字符类不得用作范围的端点。

SELECT 'justalnums' REGEXP '[[:alnum:]]+';    #结果是1

SELECT '!!' REGEXP '[[:alnum:]]+';            #结果是0

SELECT 'justalnums' REGEXP '[=alnum=]+';  #结果是1

SELECT '567' REGEXP '[=alpha=]+';  #结果是0

#正则表达式[[:<:]], [[:>:]] 这些标记表示word边界。它们分别与word的开始和结束匹配。

#word是一系列字字符,其前面和后面均没有字字符。字字符是alnum类中的字母数字字符或下划线(_)。

SELECT 'a word a' REGEXP '[[:<:]]word[[:>:]]';   #结果是1

SELECT 'a xword a' REGEXP '[[:<:]]word[[:>:]]';  #结果是0

#要想在正则表达式中使用特殊字符的文字实例,应在其前面加上2个反斜杠“\”字符。

#MySQL解析程序负责解释其中一个,正则表达式库负责解释另一个。

#例如,要想与包含特殊字符“+”的字符串“1+2”匹配,在下面的正则表达式中,只有最后一个是正确的:

SELECT '1+2' REGEXP '1+2';      #结果是0

SELECT '1+2' REGEXP '1\+2';     #结果是0

SELECT '1+2' REGEXP '1\\+2';    #结果是1

MySql 正则表达式简介及使用的更多相关文章

  1. php正则表达式简介

    正则表达式简介 正则表达式Regular Expression,使用单个字符串来描述.匹配一系列符合某个句法规则的字符串.代表性书籍<正则表达式之道>里面有详细论述,本书籍为个人查阅之用力 ...

  2. 【转】正则表达式简介及在C++11中的简单使用教程

    正则表达式Regex(regular expression)是一种强大的描述字符序列的工具.在许多语言中都存在着正则表达式,C++11中也将正则表达式纳入了新标准的一部分,不仅如此,它还支持了6种不同 ...

  3. 二十二、MySQL 正则表达式

    MySQL 正则表达式 在前面的章节我们已经了解到MySQL可以通过 LIKE ...% 来进行模糊匹配. MySQL 同样也支持其他正则表达式的匹配, MySQL中使用 REGEXP 操作符来进行正 ...

  4. mysql正则表达式及应用

    mysql where子句的模式匹配 今天在应用中遇到了这样的一个问题,有一个字段 t1,其中的值类似于:1,1,1,2,3,3,4,4,5,5,2,4,3,2,1,2 需要从里面搜索出比如说:第一个 ...

  5. DB-MySQL:MySQL 正则表达式

    ylbtech-DB-MySQL:MySQL 正则表达式 1.返回顶部 1. MySQL 正则表达式 在前面的章节我们已经了解到MySQL可以通过 LIKE ...% 来进行模糊匹配. MySQL 同 ...

  6. MySQL日志简介

    一.MySQL日志简介 二.错误日志 作用: 记录mysql数据库的一般状态信息及报错信息,是我们对于数据库常规报错处理的常用日志. 默认位置: $MYSQL_HOME/data/ 开启方式:(MyS ...

  7. 数据库----ORACLE和MYSQL数据库简介

    一.什么是数据库? 数据库(Database---DB)按照组织.储存和管理数据的仓库.(理解以下三个概念)   数据(Data)用来描述事物的记录都可称数据,如文字音乐图像.   数据库系统(Dat ...

  8. MySQL 正则表达式

    介绍 正则表达式用来描述或者匹配符合规则的字符串.它的用法和like比较相似,但是它又比like更强大,能够实现一些很特殊的规则匹配:正则表达式需要使用REGEXP命令,匹配上返回"1&qu ...

  9. MySQL正则表达式

    正则表达式作用是匹配方本,将一个模式(正则表达式)与一个文本串进行比较. MySQL用WHERE子句对正则表达式提供了初步的支持,允许你指定用正则表达式过滤SELECT检索出的数据. MySQL仅支持 ...

随机推荐

  1. vue教程1-09 交互 vue实现百度下拉列表

    vue教程1-09 交互 vue实现百度下拉列表 <!DOCTYPE html> <html lang="en"> <head> <met ...

  2. editplus来编写html

    本来写这篇文章,我可以有很多废话,但是很多都过去了,言而总之下:我暂且给这个方法起个名字,叫做“为之法”,因为有了这篇文章,很多人的想法会豁然开朗,那样有了个名字交流传阅起来就方便多了. 本方法依托于 ...

  3. nginx在centos 7中源码编译安装【添加grpc的支持】

    安装依赖软件 1.安装编译工具gcc gcc是一个开源编译器集合,用于处理各种各样的语言:C.C++.Java.Ada等,在linux世界中是最通用的编译器,支持大量处理器:x86.AMD64.Pow ...

  4. C# 泛型类在使用中约束

    首先看一下泛型的基本语法 访问修饰符 返回类型 泛型方法名 <T>(T 参数)   1):无法在泛型方法内部给任何 T 类型创建实例的对象,因为在泛型方法内部不知道传进来的对象有哪些构造函 ...

  5. Linux安装codis

    codis用go语言开发的,安装前记得先安装go开发环境,Linux安装go语言开发包 前提条件:记得安装git,否则无法下载go语言开发包 1.建立一个go语言的工作目录创建目录:sudo mkdi ...

  6. 开启linux远程访问权限

    摘要:今天在Linux服务器上安装了msyql数据库,在本地访问的时候可以访问,但是我想通过远程的方式访问的时候就不能访问了,查询资料后发现,Linux下MySQL默认安装完成后只有本地访问的权限,没 ...

  7. INTEST/EXTEST SCAN 的学习

    intest scan的一些基本知识.INTEST scan指的是对IP 内部的scan cell的扫描测试,针对IP内部的flip-flop进行shift/capture的操作.和INTEST SC ...

  8. tomcat 虚拟目录

    在webapps同级目录 下建立一个webapps_abc的目录,将网站根目录abc文件夹放入webapps_abc目录下: 找到conf目录下的,server.xml文件,在service节点下添加 ...

  9. mysql索引总结(1)-mysql 索引类型以及创建

    mysql索引总结(1)-mysql 索引类型以及创建 mysql索引总结(2)-MySQL聚簇索引和非聚簇索引 mysql索引总结(3)-MySQL聚簇索引和非聚簇索引 mysql索引总结(4)-M ...

  10. [开源] .NET数据库ORM类库 Insql

    介绍 新年之际,给大家介绍个我自己开发的ORM类库Insql.TA是一个轻量级的.NET ORM类库 . 对象映射基于Dapper , Sql配置灵感来自于Mybatis.简单优雅性能是TA的追求. ...