mysql查詢默認是不區分大小寫的 如:
1
2
3
4
5
6
7
<a href="/tags.php/select/" target="_blank">select</a> * 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慎用