当前位置: 首页 > 编程日记 > 正文

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

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

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

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 like ‘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自己解释一个,正则表达式库解释一个)

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

 

六、匹配字符类

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

 

七、匹配多个实例

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

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

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

 

八、定位符

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

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

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

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

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

用来指串的开始处

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

 

相关文章:

计算梯度幅值与方向

Mat magX Mat(src.rows, src.cols, CV_32F); Mat magY Mat(src.rows, src.cols, CV_32F); Sobel(image, magX, CV_32F, 1, 0, 3); Sobel(image, magY, CV_32F, 0, 1, 3); // 计算斜率 Mat slopes Mat(image.rows, image.cols, CV_32F); divide(magY, magX, slopes); // 计…

好程序员web前端技术分享媒体查询

为什么80%的码农都做不了架构师?>>> 好程序员web前端技术分享媒体查询 什么是媒体查询 媒体查询可以让我们根据设备显示器的特性(如视口宽度、屏幕比例、设备方向:横向或纵向)为其设定CSS样式,媒体查询由媒…

【C++】重载运算符(二)

1.4 下标运算符p501 下标运算符必须是成员函数,表示容器的类通常可以通过容器中的位置访问元素,定义下标运算符operator[]一个包含下标运算符的类,通常,定义2个版本:一个返回普通引用,另一个是类的常量成员…

手动建库11.2.0.4

环境: oracle11.2.0.4 redhat6.2 在上篇文章中,我们只安装了oracle,还没有建立实例,本篇文章就来介绍如果手动建立实例。 1.创建密码文件(password file)----非必要 cd $ORACLE_HOME/dbs/ 查看是否有init.o…

滞后阈值边缘连接

// 边缘连接 void followEdges(int x, int y, Mat &magnitude, int tUpper,int tLower, Mat &edges) { edges.at<float>(y, x) 255; for (int i -1; i < 2; i) {for (int j -1; j < 2; j) {// 边界限制if((i ! 0) && (j ! 0) && (…

《复联4》的这波操作,其实是在灭 bug

前方涉及剧透&#xff0c;请谨慎阅读&#xff01;&#xff01;&#xff01;前方涉及剧透&#xff0c;请谨慎阅读&#xff01;&#xff01;&#xff01;前方涉及剧透&#xff0c;请谨慎阅读&#xff01;&#xff01;&#xff01;↓↓↓Q1:您是否看了《复联4》&#xff1f;A、已看…

【C++】容器与继承

容器与继承 Exercise 15.28: Define a vector to hold Quote objects but put Bulk_quote objects into that vector. Compute the total net_price of all the elements in the vector. Exercise 15.29: Repeat your program, but this time store shared_ptrs to objects…

1.3 使用jmeter进行http接口测试

来源&#xff1a; http://www.cnblogs.com/alisapan/p/6150309.html 此篇纯是搬运记载。。 一、测试需求描述 1、 本次测试的接口为http服务端接口 2、 接口的主要分成两类&#xff0c;一类提供给查询功能接口&#xff0c;一类提供保存数据功能接口&#xff0c;这里我们举例2个…

opencv 自带库Canny边缘检测

#include "opencv2/imgproc/imgproc.hpp" #include "opencv2/highgui/highgui.hpp" int main( ) {// 读取源图像并转化为灰度图像cv::Mat srcImage cv::imread("..\\images\\flower.jpg",0);// 判断文件是否读入正确if( !srcImage.data ) retur…

git branch

git basic branch git branch <branchName>#create branch git branch --list#show branch list, git checkout <branchName>#choose branch,HEAD is pointer of the current branch last commit 复制代码create a file in branch 0.0.1,then checkout master ,mer…

读书笔记 effective c++ Item 5 了解c++默认生成并调用的函数

1 编译器会默认生成哪些函数 什么时候空类不再是一个空类&#xff1f;答案是用c处理的空类。如果你自己不声明&#xff0c;编译器会为你声明它们自己版本的拷贝构造函数&#xff0c;拷贝赋值运算符和析构函数&#xff0c;如果你一个构造函数都没有声明&#xff0c;编译器同样…

git tag学习记录(二)

文章目录1. git 工原理示意2. git tag记录2.1 git tag查看已有tag列表2.2 git tag标记当前分支上的 tag信息为-a v1.5.4 -m&#xff08;给指定的commit打Tag&#xff09;2.3 git push origin v1.5.4推送上一步打tag的分支到远程1. git 工原理示意 工作流程 TortoiseGit 2. g…

最小矩形与圆生成

#include "opencv2/highgui/highgui.hpp" #include "opencv2/imgproc/imgproc.hpp" #include <iostream> using namespace cv; using namespace std; int main() {cv::Mat img(500, 500, CV_8UC3);// 随机生成因子RNG& rng theRNG();for (;;){i…

详解微信域名防封的方法以及检测等工具的技术原理

微信域名完全防封是绝对不可能的&#xff0c;这是必须明确的&#xff0c;曾经有人打折《不死域名》的概念&#xff0c;它不是不死&#xff0c;是稍微命长一点&#xff0c;在推广上成本更低一下&#xff0c;效果更好一些&#xff0c;主要的技术原理是利用了腾讯云的域名安全联盟…

贝叶斯定理——数学之美

1.贝叶斯定理 1.1 定义&#xff1a;描述在已知一些条件下&#xff0c;某事件的发生概率 贝叶斯定理是关于随机事件A和B的条件概率的一则定理。 1.2 公式理解 P(x∣y)P(x)P(y∣x)P(y)P(x|y) \frac{ P(x)P(y|x)}{P(y)}P(x∣y)P(y)P(x)P(y∣x)​ 其中x以及y为随机事件&#xff…

HUST 1586 数字排列

1586 - 数字排列 时间限制&#xff1a;1秒 内存限制&#xff1a;128兆 91 次提交 36 次通过 题目描述现有n个k位的数字&#xff0c;你的任务是重新安排数字每一位的位置&#xff0c;使得重新安排后这n个数字中最大的数字和最小的数字之差的绝对值最小&#xff0c;对于每一位的调…

最小矩形与圆生成1

#include <opencv2/imgproc/imgproc.hpp> #include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp> #include <iostream> #include <stdio.h> using namespace cv; using namespace std; // 计算外接矩形与圆轮廓…

kettle-核心概念

转载于:https://www.cnblogs.com/LXL616/p/10836183.html

adb调试命令小结

adb调试命令 adb 连接android设备 adb connect 192.168.103.246 connected to 192.168.103.246:5555 sunsun:~/workspace/deptrum$ adb connect 192.168.103.246:5555 already connected to 192.168.103.246:5555 sunsun:~/workspace/deptrum$ adb shell tb8788p1_64_bsp_wxp…

github创建本地库后关联远程库

在进行新项目开发时&#xff0c;有时候并不一定先创建远程库&#xff0c;而是先在本地将项目创建&#xff0c;到一定阶段后再与远程库关联。下面步骤解决本地库与远程库在这种情形。 1. 初始化本地库&#xff0c;既然项目已经创建了&#xff0c;相信这个也已经知道了。 git ini…

mysql以及mysql bench安装教程

首先&#xff0c;我们需要去官网下载mysql&#xff08;这里以下载&#xff09; 1 2 3 4 5 下载好了自己好了之后&#xff0c;点击安装好的东西出现如下界面&#xff1a; 1、接受使用条款并点击next 2、点击custom&#xff0c;可以根据个人习惯进行安装 3、这里来是需要安装的一…

【NEON 】初探

NEON 文章目录NEON1 neon窥探1.1 neon用途1.2 neon处理机制1.3 neon发展历程中的优缺点对比1.4 为什么使用neon1.5 Armv7/v8详细差异1.6 Register寄存器1.7 指令系统间的关系与1.3相似2 neon 使用2.1 neon 指令格式2.2 AArch64 NEON 指令语法2.3 NEON 指令3.1 RK3399资料1 neon…

sql 常用 语法

2019独角兽企业重金招聘Python工程师标准>>> 1. 字段 不重复 ALTER TABLE sys_workday ADD UNIQUE (ymd) ; 转载于:https://my.oschina.net/u/1760858/blog/838385

moravec 角点检测

#include <opencv2/opencv.hpp> #include <opencv2/highgui/highgui.hpp> #include <opencv2/imgproc/imgproc.hpp> using namespace std; using namespace cv; // MoravecCorners角点检测 cv::Mat MoravecCorners(cv::Mat srcImage, int kSize, int thresho…

js控制视频播放

2019独角兽企业重金招聘Python工程师标准>>> 1、js控制视频播放 1、页面html <div id"slide" class"videoWrap"></div><canvas v-show"!isShowVideoCover" id"canvas" class"videoCanvas"><…

valgrind-yyds——memcheck检查程序中的内存问题,如泄漏、越界、非法指针等。

Valgrind 用户手册 文章目录1. valgrind概述2. Valgrind 原理及安装2.1 [Valgrind 做了什么](https://www.valgrind.org/docs/manual/manual-core.html)2.2 安装3 内存检测3.1 memcheck 常用检测指令3 .2 内存检测结果3 .3 内存检测含义3 .4 内存检测更多例子1. valgrind概述 …

数据传送到后端(二)

先在myeclipse里建立上图文件&#xff0c;然后在TestServlet.java里面的doGet{}括号里面填入以下内容&#xff1a; public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //解决中文乱码 request.setCharacte…

HSV 通道分离

// 转换成hsv cv::Mat img_h, img_s, img_v, imghsv;std::vector<cv::Mat> hsv_vec;cv::cvtColor(srcImage, imghsv, CV_BGR2HSV);cv::imshow("hsv", imghsv);cv::waitKey(0);// 分割hsv通道cv::split(imghsv, hsv_vec);img_h hsv_vec[0];img_s hsv_vec[1];i…

阿里云安全肖力:安全基础建设是企业数字化转型的基石

2019独角兽企业重金招聘Python工程师标准>>> 企业在享受数字化转型带来利好的同时&#xff0c;其面临的安全问题也愈发复杂。一方面&#xff0c;外部威胁不断升级&#xff0c;近期利用海量移动设备发起DDoS攻击的案例表明&#xff0c;黑灰产作案手法也在随着时代的发…

Shell 函数、数组与正则表达式

防伪码&#xff1a;白日依山尽&#xff0c;黄河入海流。5.1 函数格式&#xff1a;func() {command}示例 1&#xff1a;#!/bin/bashfunc() {echo "This is a function."}func# bash test.shThis is a function.Shell 函数很简单&#xff0c;函数名后跟双括号&#xf…