• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

mysql查询区分大小写高性能

mysql 搞代码 4年前 (2022-01-09) 28次浏览 已收录 0个评论

mysql查询默认是不区分大小写的 如: 1 2 3 4 5 6 7 a href=/tags.php/select/target=_blankselect/a*fromtable_namewherealike’a%’ sele本文来源gaodai$ma#com搞$代*码网2ct*fromtable_namewherealike’A%’ select*fromtable_namewherealike’a%’ select*fromtable_namewherealike’A%’ 效果

mysql查询默认是不区分大小写的 如:

1

2

3

4

5

6

7

select * from table_name where a like ‘a%’

select * from table_name where a like ‘A%’

select * from table_name where a like ‘a%’

select * from table_name where a like ‘A%’

效果是一样的。

要让mysql查询区分大小写,可以:

1

2

3

4

5

6

7

select * from table_name where binary a like ‘a%’

select * from table_name where binary a like ‘A%’

select * from table_name where binary a like ‘a%’

select * from table_name where binary a like ‘A%’

也可以在建表时,加以标识

1

2

3

4

5

6

7

8

9

10

11

create table table_name(

a varchar (20) binary

)

create table table_name(

a varchar(20) binary

)

测试30W数据

1

SELECT * FROM `tableName` WHERE ( BINARY weixin = ‘value’ ) LIMIT 1;

不支持索引,查询效率底下,不建议考虑。上面这些sql语句乍看不会有什么问题,但是当表中的数据多了以后,问题就会凸显出来,用不到索引,就会导致查询效率非常低下。

支持索引,查询效率高(推荐使用)

1

SELECT * FROM `tableName` WHERE weixin = ‘value’ COLLATE utf8_bin LIMIT 1;

查询分析如下:

通过以上描述可以很清晰的看到两个sql在效率上的根本区别,binary慎用


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql查询区分大小写高性能

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址