mysql字符串区分⼤⼩写的问题
⼀、
1、 CREATE TABLE NAME(name VARCHAR(10));
小写字符串是什么对这个表,缺省情况下,下⾯两个查询的结果是⼀样的:
SELECT * FROM TABLE NAME WHERE name='clip';
SELECT * FROM TABLE NAME WHERE name='Clip';
MySql默认查询是不区分⼤⼩写的,如果需要区分他,必须在建表的时候,Binary标⽰敏感的属性.
CREATE TABLE NAME(
name VARCHAR(10) BINARY
);
2、在SQL语句中实现 SELECT * FROM TABLE NAME WHERE BINARY name='Clip';
3、设置字符集:
utf8_general_ci --不区分⼤⼩写
utf8_bin--区分⼤⼩写
⼆、 MySQL在windows下是不区分⼤⼩写的,将script⽂件导⼊MySQL后表名也会⾃动转化为⼩写,结果再想要将数据库导出放到linux服务器中使⽤时就出错了。
因为在linux下表名区分⼤⼩写⽽不到表,查了很多都是说在linux下更改MySQL的设置使其也不区分⼤⼩写,但是有没有办法反过来让windows 下⼤⼩写敏感呢。
其实⽅法是⼀样的,相应的更改windows中MySQL的设置就⾏了。
具体操作:
在MySQL的配置⽂件my.ini中增加⼀⾏:
lower_case_table_names = 0
其中 0:区分⼤⼩写,1:不区分⼤⼩写
MySQL在Linux下数据库名、表名、列名、别名⼤⼩写规则是这样的:
1、数据库名与表名是严格区分⼤⼩写的;
2、表的别名是严格区分⼤⼩写的;
3、列名与列的别名在所有的情况下均是忽略⼤⼩写的;
4、变量名也是严格区分⼤⼩写的; MySQL在Windows下都不区分⼤⼩写
当我们输⼊不管⼤⼩写都能查询到数据,例如:输⼊ aaa 或者aaA ,AAA都能查询同样的结果,说明查询条件对⼤⼩写不敏感。
解决⽅案⼀:
于是怀疑Mysql的问题。做个实验:直接使⽤客户端⽤sql查询数据库。发现的确是⼤⼩不敏感。
通过查询资料发现需要设置collate(校对)。 collate规则:
*_bin: 表⽰的是binary case sensitive collation,也就是说是区分⼤⼩写的
*_cs: case sensitive collation,区分⼤⼩写
*_ci: case insensitive collation,不区分⼤⼩写
解决⽅法⼀:
1.可以将查询条件⽤binary()括起来。⽐如:
select * from TableA where binary columnA ='aaa';
2. 可以修改该字段的collation 为 binary
⽐如:
ALTER TABLE TABLENAME MODIFY COLUMN COLUMNNAME VARCHAR(50) BINARY CHARACTER SET utf8 COLLATE
utf8_bin DEFAULT NULL;
解决⽅案⼆:
mysql查询默认是不区分⼤⼩写的如:
select * from some_table where str=‘abc';
select * from some_table where str='ABC';
得到的结果是⼀样的,如果我们需要进⾏区分的话可以按照如下⽅法来做:
第⼀种⽅法:
要让mysql查询区分⼤⼩写,可以:
select * from some_table where binary str='abc'
select * from some_table where binary str='ABC'
第⼆种⽅法:
在建表时时候加以标识
create table some_table(
str char(20) binary
)
原理:
对于CHAR、VARCHAR和TEXT类型,BINARY属性可以为列分配该列字符集的校对规则。BINARY属性是指定列字符集的⼆元校对规则的简写。
排序和⽐较基于数值字符值。因此也就⾃然区分了⼤⼩写。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。