前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MYSQL 从正则查询 扯到 查询中的大小写敏感的解决方法

MYSQL 从正则查询 扯到 查询中的大小写敏感的解决方法

作者头像
AustinDatabases
发布2019-07-30 18:17:50
2.6K0
发布2019-07-30 18:17:50
举报
文章被收录于专栏:AustinDatabasesAustinDatabases

MYSQL 中的查询给人的观念大多是简单的,不复杂的,将复杂的事情都交给程序来做,数据库就是一个容器的概念或一个固化的观念。

其实随着MYSQL8 的到来,越来越多以前不能在SQL 端执行的语句,可以在MYSQL中执行,例如CTE ,窗口函数,等等,而查询中有的是使用like来查,而LIKE 的查询中有一些查询比较复杂,而正则表达式在SQL 查询中的使用可以帮助一些复杂查询的表达和实现。总结起来,MYSQL 正在从街边的小屁孩,变成那个拒绝钢铁侠出席会议的蜘蛛侠。(如果你最近看了MYSQL 8.017 的那个版本的变化)

怎么能进行这样的查询,我们来看下面几个例子

1 如我们要查询 employees 表中 first_name 是 G 开头的名字的人有多少

这里我们可以使用 Rlike 来操作 正则表达式

select count(*) from employees where first_name RLIKE '^G';

这里G 开头的 first_name 的人有 1万6千多人

下面有一个需求,想找到 G 大小开头的,中间是字母的 结尾是 i 的 firstname

下面的语句应该能满足你的需求

select * from employees where first_name RLIKE '^G[a-z]' and first_name RLIKE 'i$'

3 查询 G 开头 uo 在 第二第三 字符位置的 first_name

select * from employees where first_name RLIKE '^G[uo]{2,3}';

4 而实际当中面临的一些问题,有的时候也需要使用正则表达式来解决

例如 下图,我们遇到 first_name 写法有些怪异但如果按照平时的查询的方法,会将他们一股脑的都查询出来

select * from employees where first_name = 'georgi';

我们使用上面的语句来查询,结果可想而知,会不区分大小写来将所有的Georgi gEORGI 都查出来

其实在早期的MYSQL 的版本 5.X 之前 正则表达式是可以区分大小写的

但现在的版本是不能区分的。

如何让目前的正则表达式能区分出大小写

我们可以在 你要查询的字段名前加上 binary 然后匹配正常的正则,你就可以查到你要查的数据了,请见上图

那么问题来了,题目说扯到大小写敏感,你上面那个能算是扯到大小写敏感吗,如果我不用正则表达式,或者我不愿意在字段前面加binary ,你怎么解决我大小写敏感的问题。

说扯咱们就扯,直接跳到疗效,看我下边没有使用 binary哟,照样扯到,不不不 是查到了 数据。

不用正则也可以

有人可能马上说,你表里就那一条记录吧,来看下图,当然不是

问题就扯出来了,到底我搞了什么,让MYSQL first_name 大小写敏感了

答案就在图里面,修改字段后面加binary 就可以了

好的今天就扯到这里。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-07-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 AustinDatabases 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档