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

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 就可以了

好的今天就扯到这里。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值