手机
当前位置:查字典教程网 >编程开发 >mysql数据库 >mysql查询区分大小写高性能
mysql查询区分大小写高性能
摘要:mysql查询默认是不区分大小写的如:1234567ahref="/tags.php/select/"target="_blank"sele...

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

1 2 3 4 5 6 7 a href="/tags.php/select/" target="_blank"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语句乍看不会有什么问题,但是当表中的数据多了以后,问题就会凸显出来,用不到索引,就会导致查询效率非常低下。

mysql查询区分大小写高性能1

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

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

查询分析如下:

mysql查询区分大小写高性能2

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

【mysql查询区分大小写高性能】相关文章:

mysql 中文乱码 解决方法集锦

mysql数据库子分区教程

mysql多表随机查询优化方案

去掉mysql连接时报警声音的方法

mysql主从库不同步问题解决方法

SQL查询语句中的bool类型字段值的写法

mysql误删root用户或者忘记root密码解决方法

mysql锁表和解锁语句分享

mysql_stat()查询MySQL服务器当前系统状态

mySQL 延迟 查询主表

精品推荐
分类导航