MySQL的大小写敏感

来源:这里教程网 时间:2026-03-01 18:32:44 作者:

1.和数据库名字、表名字、存储过程和触发器有关Mysql中控制数据库名和表名的大小写敏感是由参数 lower_case_table_names控制,为0时;表示区分大小写,使用CREATE TABLE或CREATE DATABASE语句指定的大小写字母在硬盘上保存表名和数据库名。名称比较对大小写敏感。在大小写不敏感的操作系统如windows或Mac OS x上我们不能将该参数设为0,如果在大小写不敏感的文件系统上将--lowercase-table-names强制设为0,并且使用不同的大小写访问MyISAM表名,可能会导致索引破坏。 为1时;表示将名字转化为小写后存储,名称比较对大小写不敏感。MySQL将所有表名转换为小写在存储和查找表上。该行为也适合数据库名和表的别名。该值为Windows的默认值。 为2时;表名和数据库名在硬盘上使用CREATE TABLE或CREATE DATABASE语句指定的大小写字母进行保存,但MySQL将它们转换为小写在查找表上。名称比较对大小写不敏感,即按照大小写来保存,按照小写来比较。注释:只在对大小写不敏感的文件系统上使用! innodb表名用小写保存。 如果你使用innodb表,为了避免避免大小写敏感问题,可以把lower_case_table_names=1 把 lower_case_table_names从0改变为1在你把lower_case_table_names设置为1时,在restart你的mysqld之前,请把数据库名和表名更改为小写 mysql> RENAME TABLE T1 TO t1; 2.和字段名字有关字段名是不区分大小写的 3.和字段值有关,用于字符串比较字段值的大小写由Mysql的collate来控制。提到collate,就不得不说字符集。字符集是一套符号和编码,collate是在字符集内用于比较字符的一套规则,比如定义'A'<'B'这样的关系的规则。不同的字符集有多种校对规则,一般而言,collate以其相关的字符集名开始,通常包括一个语言名,并且以_ci(大小写不敏感)、_cs(大小写敏感)或_bin(二元)结束 。 比如 utf8字符集:utf8_general_ci,表示不区分大小写,这个是utf8字符集默认的collate;utf8_general_cs表示区分大小写,utf8_bin表示二进制比较,同样也区分大小写。 4. 在查询时指定大小写

root@localhost [test]> select * from t where custid like 'a%';
+---------+------------+-------+--------+-----+
| orderid | orderdate  | empid | custid | qty |
+---------+------------+-------+--------+-----+
|       1 | 2010-01-02 |     3 | A      |  10 |
|       3 | 2010-05-02 |     1 | A      |  30 |
|       5 | 2011-01-02 |     4 | A      |  20 |
|       8 | 2009-01-02 |     2 | A      |  10 |
+---------+------------+-------+--------+-----+
select * from t where custid like binary 'a%';
Empty set (0.00 sec)

或者

create table t1 like t;
alter table t1 modify custid varchar(10) binary;
insert into t1 select * from t;
select * from t1 where custid like 'a%';
Empty set (0.00 sec)

 

相关推荐