mysql区分大小写的设置
2013-05-29 14:37
459 查看
查询数据时查询条件输入不管大小写,都能查到同样的数据。 比如: 输入 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,不区分大小写
解决方法。
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 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开头的记录都将返回
因为程序使用了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开头的记录都将返回
相关文章推荐
- mysql设置不区分大小写
- MySQL表名不区分大小写的设置方法
- MySQL表名不区分大小写的设置方法
- mysql设置不区分大小写
- 设置Linux下Mysql表名不区分大小写
- 设置Linux下Mysql表名不区分大小写
- Mysql表名不区分大小写设置
- 设置Linux下Mysql表名不区分大小写
- MySQL表名不区分大小写的设置方法
- Windows下MySql设置表区分大小写(统一window与linux的区分表大小写)
- linux下设置mysql不区分大小写
- mysql区分大小写列设置
- MySQL数据表中内容大小写区分的设置
- 设置Linux下Mysql表名不区分大小写
- 在mysql中设置utf8_bin下 like搜索 不想区分大小写
- MySQL表名不区分大小写的设置方法
- 设置Linux下Mysql表名不区分大小写
- MySQL表名不区分大小写的设置方法
- MySQL表名不区分大小写的设置方法
- MySQL表名不区分大小写的设置方法