• BiaoDoo首页
  • 自主产品
       自主产品
       测试工具
       源码安全/质量测试云平台
       测试用例开发工具
       软件测试态势分析平台
       开源软件安全审计系统
       软件造价
       软件造价概算平台
       运维产品
       应用源码监测系统
       教学实训平台
       软件测试实验室平台
  • Micro Focus产品代理
       Micro Focus产品代理
       Fortify SCA
       Webinspect
       LoadRunner
       ALM/QualityCenter
       MF UFT
       MF Mobile Center
       Diagnostics
  • 其它产品
       其它产品
       AppScan(IBM)
       Klockwork Insight
       Coverity静态分析
       Black Duck--黑鸭软件成分分析
  • 安全产品
       安全产品
       U盾
  • 工程咨询
       工程咨询
       IT规划咨询
       软件造价概算
       软件架构评估
       信息工程监理
       测试体系咨询
  • 软件测试
       软件测试
       工程验收测试
       压力测试与优化
       产品认证测试
       专题测试
       医疗设备软件测试
       摇号软件测试
       科研项目验收
       软件故障诊断
       委托客制测试
       软件登记测试
       科技成果鉴定
       国产软件适配测试
  • 安全测试
       安全测试
       软件安全测试
       源码安全测试
       等级保护测评
       渗透测试
       风险评估
  • 企业服务
       企业服务
       系统保障与救援
       大数据服务
       ICP证书办理
       软件著作权
       首版次申报
  • 教育培训
       教育培训
       ISTQB认证
       软件产品检验员
       软件就业培训
       校企合作
       信息安全培训
  • 认证中心
       认证中心
       软件企业认证
       质量安全体系认证
       高新技术企业认证
       企业能力认证
       节能与绿色评价服务
       其它系统认证
  • 资讯中心
       资讯中心
       最新资讯
       政策法规
       技术方案
  • 开源测试 · 青云渡
       开源测试 · 青云渡
       技术文摘
       BiaoDoo开源
       常用工具
  • 全国网络
       全国网络
  • BiaoDoo
       BiaoDoo
       软件管控领导者
       合作伙伴
       FAQ
       加入我们
       招聘信息
       合作加盟
       联系我们
  • 测试外包
       测试外包
       离岸测试外包
       测试人才外协
  • 开源测试 · 青云渡

    Windows下 MySQL大小写敏感配置

    最近在window系统下 操作Linux系统下创建的数据库,发现有些不对劲,比较了半天才发现是大小写敏感的问题造成的。网上搜索了一下,解决了这个问题,做个简明扼要的记录。

     按照网上的说明:


     WINDOWS:

    编辑MySQL安装目录下的my.ini 文件,在[mysqld]节下 添加 lower_case_table_names=0 (备注:为0时大小写敏感,为1时大小写不敏感,默认为1),可以实现MySql按照建表Sql语句的大小写状态来定义表名。


      

    具体操作的时候会发现,理论和实践总是有差异的:


     我的MySQL安装路径为:C:\Program Files\MySQL\MySQL Server 5.7\bin(网上有的说my.ini配置文件在这个文件夹下)

    但是my.ini所在的文件路径为:C:\ProgramData\MySQL\MySQL Server 5.7\my.ini

    然后在[mysqld]节下 添加 lower_case_table_names=0。

    配置好文件了,去试一下咋样。

    重新连接数据库,发现数据库连接失败,然后去查了一下MySQL服务,发现MySQL服务无法启动(本地计算机上的mysql服务启动后停止,某些服务在未由其他服务或程序使用时将自动停止)。只能把mysqld恢复原来的样子,也就是把“lower_case_table_names=0”这句话删了。

    查找资料,看到说“大小写敏感要操作系统支持,Windows本身大小写不敏感,因此不能设置这一项”。在另一个博文里看到了官方手册的网址链接,按捺不住好奇心去看一下。发现上面的这个配置是不可行的(具体分析见下面的划重点)

    可能出现的错误可参见这篇求助博文的内容以及下面的讨论

     

    MySQL官网手册-大小写敏感说明:

    (在官网说明的基础上加上我的独家中文解说 O(∩_∩)O~英文好的同学最好直接看英文文档,说的比较清楚)


    How table and database names are stored on disk and used in MySQL is affected by the lower_case_table_names system variable, which you can set when starting mysqldlower_case_table_names can take the values shown in the following table. This variable does not affect case sensitivity of trigger identifiers. On Unix, the default value of lower_case_table_names is 0. On Windows, the default value is 1. On OS X, the default value is 2.

    PS:mac OS(2012年前称Mac OS X,2012年-2016年称OS X)

    ValueMeaning
    0

    Table and database names are stored on disk using the lettercase specified in the CREATE TABLE or CREATE DATABASE statement. Name comparisons are case sensitive.

    (总结:存储和查询的时候都大小写敏感,都要是按照建表时指定的写法)

    You should not set this variable to 0 if you are running MySQL on a system that has case-insensitive file names (such as Windows or OS X). If you force this variable to 0 with --lower-case-table-names=0 on a case-insensitive file system and access MyISAM tablenames using different lettercases, index corruption may result.此处划重点

    1

    Table names are stored in lowercase on disk and name comparisons are not case sensitive. MySQL converts all table names to lowercase on storage and lookup. This behavior also applies to database names and table aliases.

    (总结:存储和查询的时候大小写都不敏感,都转换为小写字母)

    2

    Table and database names are stored on disk using the lettercase specified in the CREATE TABLE or CREATE DATABASE statement, but MySQL converts them to lowercase on lookup. Name comparisons are not case sensitive. This works only on file systems that are not case sensitive! InnoDB table names are stored in lowercase, as for lower_case_table_names=1.

    (总结:存储时大小写敏感,按照建表时指定的写法;查询时都转换为小写字母)

     

    1、单平台:If you are using MySQL on only one platform, you do not normally have to change the lower_case_table_names variable from its default value.

    2、跨平台:However, you may encounter difficulties if you want to transfer tables between platforms that differ in file system case sensitivity. For example, on Unix, you can have two different tables named my_table and MY_TABLE, but on Windows these two names are considered identical. To avoid data transfer problems arising from lettercase of database or table names, you have two options:(跨平台的MySQL大小写敏感解决方案在此!!!看看官网怎么说~

    • Use lower_case_table_names=1 on all systems. The main disadvantage with this is that when you use SHOW TABLES or SHOW DATABASES, you do not see the names in their original lettercase.

    • Use lower_case_table_names=0 on Unix and lower_case_table_names=2 on Windows. This preserves the lettercase of database and table names. The disadvantage of this is that you must ensure that your statements always refer to your database and table names with the correct lettercase on Windows. If you transfer your statements to Unix, where lettercase is significant, they do not work if the lettercase is incorrect.

      Exception: If you are using InnoDB tables and you are trying to avoid these data transfer problems, you should set lower_case_table_names to 1 on all platforms to force names to be converted to lowercase.

    有点复杂。。。本来看懂了的,又出来了个Exception。。。本来愉悦的心情又down了,因为我的table就是InnoDB,看了半天想去配置文件大展身手来着。。。

     

    好吧,那就先不管跨不跨平台了,也不管配置文件my.ini了。直接上手使用的话,想要区别大小写,可以在查询语句的时候加上Binary,具体实现如下:


    (此段文字的参考博文:http://www.cnblogs.com/softidea/p/6047766.html。在此博文的基础上,内容已大幅度精简提炼)

    参考方案:

    1、在建表时指定大小写敏感:

      MySql默认查询是不区分大小写的,如果需要区分他,必须在建表的时候,Binary标示敏感的属性.

      CREATE TABLE NAME(
      name VARCHAR(10)  BINARY);

    2、 在查询条件的字段名前 加上binary:

      在SQL语句中实现 SELECT * FROM TABLE NAME WHERE BINARY name='Clip';

    3、 建表时设置字符集使其大小写敏感:

      utf8_general_ci --不区分大小写

      utf8_bin--区分大小写

    【设置collate(校对) 。 collate规则:

      *_bin: 表示的是binary case sensitive collation,也就是说是区分大小写
      *_cs: case sensitive collation,区分大小写
      *_ci: case insensitive collation,不区分大小写 】

    4、可以修改该字段的collation 为 binary
    比如:
    ALTER TABLE TABLENAME MODIFY COLUMN COLUMNNAME VARCHAR(50) BINARY CHARACTER SET utf8  COLLATE utf8_bin DEFAULT NULL;

     

    实践:在Win7 系统下进行测试:


     1、在创建数据库的时候指定为大小写敏感,尝试将数据库名称写为大小写混合的模式,发现行不通。。。由下面的错误提示可知,数据库名称和表名都只能是小写字母。

    2、建表的时候指定大小写敏感(utf8-bin),如下图:

    进行简单的测试,发现:可以区分大小写了!

    表中全部的数据为:

    执行查询语句:SELECT * FROM mysql_test.coding WHERE Name = 'zhou'; 

    查询的结果只返回了一条大小写完全匹配的记录,如图:

     

    实践总结:


     做了几组实验之后得出结论:

    • 无论在创建数据库(schemas)时是否指定collation为utf8-bin,只要在创建数据表(table)时指定了collation为utf8-bin就可以实现字符集的大小写敏感。

    • 即使创建数据库时指定了collation为utf8-bin,如果在创建数据表(table)时未指定collation为utf8-bin,那么在查询时依然不能实现字符集的大小写敏感。

    • 综合以上两条结论:只要创建数据表时没有指定collation为utf8-bin,在Windows下就无法实现大小写敏感。这种情况下,如上一节所述,只能在查询时 在字段前指定BINARY或者更改字段的默认collation为utf8-bin:

         ALTER TABLE `mysql_test`.`coding` 

         CHANGE COLUMN `Name` `Name` VARCHAR(45) CHARACTER SET 'utf8' NULL DEFAULT NULL ;

     

    作者:zoery 出处:http://www.cnblogs.com/swje/ 欢迎转载或分享,但请务必声明文章出处。