因为程序使用了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,不区分大小写
解决方法。
1.可以将查询条件用binary()括起来。 比如: select * from TableA where columnA like binary('aaa');
2. 可以修改该字段的collation 为 binary
比如:
ALTER TABLE `tablename` MODIFY COLUMN `cloname` VARCHAR(45) BINARY
ALTER TABLE TABLENAME MODIFY COLUMN COLUMNNAME VARCHAR(50) BINARY CHARACTER SET utf8 COLLATEutf8_bin DEFAULT NULL;
解决该问题
如何不区分大小写:
mysql默认的设置或是对整个库的设置
是否区分大小写和校对规则有关,默认设的规则是大小写不敏感的。
show create table如果看到collate是ci结尾,那么就是不区别的,如果cs或bin结尾,就是区别的。
如果建表的时候选择的是区别大小写的规则而查询的时候又暂时不想区别,
可以用类似
WHERE column_name COLLATE utf8_general_ci ,根据使用字符集的不同改变general_ci。
的写法改变查询使用的校对规则。
MySQL使用like搜索不区分大小写方法之一
SQL代码:
- col_name COLLATE xxx_general_cs LIKE 'a%'
- col_name LIKE 'a%' COLLATE xxx_general_cs
- col_name COLLATE xxx_bin LIKE 'a%'
- col_name LIKE 'a%' COLLATE xxx_bin
使用a搜索,以a或A开头的记录都将返回