今天遇到一個狀況, 查詢數據時查詢條件輸入無論大小寫,都能查到一樣的數據。 好比: 輸入 aaa 或者aaA ,AAA都能查詢一樣的結果,說明查詢條件是大小寫不敏感的。 mysql
由於程序使用了hibernate框架訪問mysql數據庫。 一開始覺得是hibernate的問題。 最跟蹤了一下hibernate代碼沒有看到轉換大小寫的步驟,最後確認hibernate其實只不過是將hql轉化爲sql。大小寫不敏感和 hibernate沒有關係。sql
因而懷疑Mysql的問題。作個實驗:直接使用客戶端用sql查詢數據庫。 發現的確是大小不敏感 。數據庫
經過查詢資料發現須要設置collate(校對) 。 collate規則:框架
*_bin: 表示的是binary case sensitive collation,也就是說是區分大小寫的
*_cs: case sensitive collation,區分大小寫
*_ci: case insensitive collation,不區分大小寫hibernate
解決方法。ci
1.能夠將查詢條件用binary()括起來。 好比: select * from TableA where columnA like binary('aaa'); it
2. 能夠修改該字段的collation 爲 binary io
好比:select
ALTER TABLE TABLENAME MODIFY COLUMN COLUMNNAME VARCHAR(50) BINARY CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL;程序
解決該問題