程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> mysql查詢區分大小寫高性能

mysql查詢區分大小寫高性能

編輯:關於MYSQL數據庫

     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語句乍看不會有什麼問題,但是當表中的數據多了以後,問題就會凸顯出來,用不到索引,就會導致查詢效率非常低下。

    mysql查詢區分大小寫高性能 三聯

     

     

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

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

    查詢分析如下:



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

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved