首页 > 数据库 >MySQL(三)用正则表达式搜索

MySQL(三)用正则表达式搜索

时间:2023-02-01 14:34:09浏览次数:39  
标签:字符 匹配 正则表达式 column 搜索 MySQL regexp where


正则表达式是用来匹配文本的特殊的串(字符集合),将一个模式(正则表达式)与一个文本串进行比较;

所有种类的程序设计语言、文本编辑器、操作系统等都支持正则表达式,正则表达式用正则表达式语言来建立;

MySQL仅支持多数正则表达式实现的一个很小的子集;

 

一、基本字符匹配

select column from table where column regexp ‘1000’ order by column;

该语句检索列column包含文本1000的所有行;它告诉MySQL:regexp后所跟的东西作为正则表达式(与文字正文1000匹配的一个正则表达式)处理。

select column from table where column regexp ‘.000’ order by column;

该语句中的正则表达式(.),是正则表达式语言中的一个特殊字符,表示匹配任意一个字符(该语句也可以使用like和通配符完成)

like和regexp的区别:

①like匹配整个列;

select column from table where column regexp ‘1000’ order by column;

该SQL语句将不返回数据,因为like匹配整个列,如果被匹配的文本在列值中出现,like将不会找到它,相应的行也不会被返回(除非使用通配符)

②regexp在列值内进行匹配

select column from table where column regexp ‘1000’ order by column;

该SQL语句会返回一行数据,如果被匹配的文本在列值中出现,regexp将会找到它,相应的行将被返回(如果希望regexp匹配整个列值,使用^和$定位符{anchor})即可

MySQL中正则表达式匹配不区分大小写,如希望区分大小写,可使用binary关键字,如where column regexp binary ‘test .000’

 

二、进行or匹配

select column from table where column regexp ‘X|Y’ order by column;

or表示匹配其中之一,功能雷雨与select语句中的or语句,多个or条件可并入单个正则表达式

 

三、匹配几个字符之一

select column from table where column regexp ‘[XYZ]test’ order by column;

[]是另一种形式的or语句,作用是匹配指定的(其中之一)字符;正则表达式[XY]test为[X|Y|Z]test的缩写,它的意思是匹配X或者Y或者Z

字符集合也可以被否定,即匹配除指定字符外的任何东西,为否定一个字符集,可以在集合开始处设置一个‘^’例如[^XYZ]([]定义更准确,|如果不括起来,则应用于整个串)

 

四、匹配范围

集合可以用来定义要匹配的一个或多个字符

比如[0123456789],为了简化这种类型的集合,可使用(-)来定义一个范围,即[0-9];(范围不仅仅局限于数值,还可以使字母字符等)

 

五、匹配特殊字符

正则表达式由具有特定含义的特殊字符构成;如果要匹配这些特殊字符,就需要用\\为前导;\\-表示查找-,\\.表示查找.

select column from table where column regexp ‘\\-’ order by column;

这种处理方式就是所谓的转义(escaping),正则表达式内具有特殊意义的所有字符都必须以这种方式转义;(为了匹配反斜杠{\}字符本身,需要使用\\\)

PS:多数正则表达式实现使用单个反斜杠转义特殊字符,以便能够使用这些字符本身,而MySQL要求两个反斜杠(MySQL自己解释一个,正则表达式库解释一个)

\\也用来引用元字符(具有特殊含义的字符),如下:

MySQL(三)用正则表达式搜索_mysql

 

六、匹配字符类

字符类(character class):有时候需要检索出我们需要的数字、所有字母字符或所有数字字母字符等的匹配,我们可以使用预定义的字符集,称为字符类;如下:

MySQL(三)用正则表达式搜索_mysql_02

 

七、匹配多个实例

有时候需要对匹配的数目进行更强的控制,比如:寻找所有的数,不管数中包含多少数字,或寻找一个单词并尾随一个s(如果存在)等情况,我们可以利用正则表达式中的重复元字符来完成;如下

MySQL(三)用正则表达式搜索_mysql_03

select column from table where column regexp ‘\\([0-9] sticks?\\)’ order by column;

上面的正则表达式‘\\([0-9] test?\\)’意为:\\匹配([0-9]匹配任意数字,这里指匹配的数值范围,sticks?匹配stick和sticks{?使s可选,因为?匹配它前面任何字符的0或者1次出现})

 

八、定位符

有时候为了匹配特定位置的文本,需要使用定位符,常用定位符列表如下:

MySQL(三)用正则表达式搜索_mysql_04

例如:找出一个以一个数(包括小数点开始的数)开始的所有数值,简单搜索[0-9\\.]或([[:digit:]\\.])不行,因为它将在文本内任意位置查找匹配,可以使用^定位符,如下

select column from table where column regexp '^[0-9\\.]' order by column;

^匹配串的开始,有两种用法:

①在集合中(用[和]定义),用它来否定该集合

②用来指串的开始处

使regexp和like起相同作用:like匹配整串二regexp匹配子串,可以利用定位符,用^开始每个表达式,用$结束每个表达式,就可以使regexp和like作用一样

标签:字符,匹配,正则表达式,column,搜索,MySQL,regexp,where
From: https://blog.51cto.com/u_15950441/6031566

相关文章

  • MySQL(一)MySQL基础介绍
    最近的学习内容是数据库相关的一些知识,主要以MySQL为主,参考书籍——《MySQL必知必会》MySQL学习及下载地址:https://dev.mysql.com/MySQL学习使用注意事项:1、必须访问一个已......
  • MySql 中 case when then else end 的用法
    解释:SELECTcase-------------如果whensex='1'then'男'-------------sex='1',则返回值'男'whensex='2'then'女'--------......
  • 分享会上狂吹MySQL的4大索引结构,没想到大家的鉴赏能力如此的~~~~
    索引(index)是帮助MySQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据......
  • 分享会上狂吹MySQL的4大索引结构,没想到大家的鉴赏能力如此的~~~~
    文章内容整理自【博学谷狂野架构师】索引(index)是帮助MySQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种......
  • mysql-mysqldump命令详解
    注意:备份加入--databases备份文件中会有创建数据库的语句,否则没有建议:导出库加入、导出表不加此参数一、mysqldump命令备份Mysql数据库的参数说明在用mysqldump备份使用......
  • 分享会上狂吹MySQL的4大索引结构,没想到大家的鉴赏能力如此的~~~~
    索引(index)是帮助MySQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数......
  • mysql explain详解
    本文转载自 https://www.cnblogs.com/LoveBB/p/15181075.htmlExplain关键字是Mysql中sql优化的常用「关键字」,通常都会使用Explain来「查看sql的执行计划,而不用执行sql」......
  • 9.搜索查找命令
      查找当前目录下的文件  查找规定目录下的文件   *在shell中表示通配符,表示零个或多个字符。比如当前目录下有abc.c、abdd.c、abeff.c。可以用lsab*.c来......
  • mysql缓存-Buffer Pool总结
    1.磁盘太慢,用内存作为缓存很有必要。2.BufferPool本质上是InnoDB向操作系统申请的一段连续的内存空间,可以通过innodb_buffer_pool_size来调整它的大小。3.Buffer......
  • java正则表达式不包含特殊字符验证
    原文链接:https://blog.csdn.net/weixin_39625782/article/details/114674258packagecom.sodii.regex.demo;importjava.util.regex.Matcher;importjava.util.regex.Pa......