萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> mysql查詢區分大小寫高性能

mysql查詢區分大小寫高性能

在mysql中區分大小寫通常是指字母了,如果我們不進行一些特殊的設置A與a在mysql中查出來的結果是完全一樣的,那麼要如何實現區分大小寫查詢呢?下面就和111cn小編來看看。


mysql查詢默認是不區分大小寫的 如:

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查詢區分大小寫,可以:
 

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%'

也可以在建表時,加以標識
 

create  table  table_name(   

     a varchar (20) binary     

)  

create table table_name(

     a varchar(20) binary 

)

測試30W數據

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

不支持索引,查詢效率底下,不建議考慮。上面這些sql語句乍看不會有什麼問題,但是當表中的數據多了以後,問題就會凸顯出來,用不到索引,就會導致查詢效率非常低下。

 

 

支持索引,查詢效率高(推薦使用)

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

查詢分析如下:



通過以上描述可以很清晰的看到兩個sql在效率上的根本區別,binary慎用

 

copyright © 萬盛學電腦網 all rights reserved