欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

MYSQL 从常规查询到大小写敏感查询解决方案

最编程 2024-04-01 20:03:57
...

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

好的今天就扯到这里。