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