前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL WHERE子句内使用正则表达式搜索

MySQL WHERE子句内使用正则表达式搜索

作者头像
秋白
发布2018-05-24 13:30:07
1.2K0
发布2018-05-24 13:30:07
举报
文章被收录于专栏:java小白java小白
正则表达式之初见

下面的语法检索列prod_name包含文本1000的所有行

代码语言:javascript
复制
SELECT * FROM products WHERE prod_name REGEXP '1000';
这里写图片描述
这里写图片描述

使用正则表达式语言中一个特殊的字符.,它表示匹配任意一个字符

代码语言:javascript
复制
SELECT * FROM products WHERE prod_name REGEXP '.000';
这里写图片描述
这里写图片描述

代码语言:javascript
复制
SELECT * FROM products WHERE prod_name LIKE '1000';
和
SELECT * FROM products WHERE prod_name REGEXP '1000';

执行上面两条语句,会发现第一条语句不返回数据,而第二条语句会返回一条。

这里写图片描述
这里写图片描述

LIKE匹配整个列。如果被匹配的文本在列值中未出现,LIKE将不会找到它,相应的行也不被返回(除非使用通配符)。而REGEXP在列值内进行匹配,如果被匹配的文本在列值中出现,REGEXP将会找到它,相应的行将被返回。REGEXP也能匹配整个列(和LIKE相同的作用)使用^和$定位符即可。


MySQL中正则表达式匹配不区分大小写(即,大写和小写都匹配)。为区分小写,可用BINARY关键字。

这里写图片描述
这里写图片描述
正则表达式之匹配特殊字符

正则表达式语言由具有特定含义的特殊字符构成。如果需要匹配特殊字符,应该怎么办,例如匹配 . 的值,需要转义, 需要用\为前导。\\表示查找\,\.表示查找.。

这里写图片描述
这里写图片描述

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

正则表达式之定位元字符

^表示文本的开始 $表示文本的结尾 [[:<:]]表示词的开始 [[:>:]]表示词的结尾 例如匹配文本以1开头的文本

这里写图片描述
这里写图片描述
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018年02月01日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 正则表达式之初见
  • 正则表达式之匹配特殊字符
  • 正则表达式之定位元字符
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档