bitscn.com
以前都是使用linux平台下的mysql,现在为了调试方便,在开发机上安装了mysql的windows版本5.6.10,在使用entity framework code first生成数据库对象时,发现所有的数据表的表名都变成了小写字符,而字段的名称是混合大小写的,这个问题在linux平台上没有出现过,于是着手弄明白这是肿么一回事。
经过网上搜索,找到这篇文章:
entity framework with mysql, table capitalization issue between linux and windows大致的意思是说:这个问题产生的根源是操作系统,mysql保存数据表到文件,最初mysql是在linux平台开发的,文件名和数据表名称都是大小写敏感的,因为绝大多数的linux文件系统是大小写敏感的。
后来,mysql推出windows平台的版本,而windows平台是大小写不敏感的,所以无法区分大小写的名称。为了解决这个问题,需要添加设置来忽略表名的大小写。于是建立了lower_case_table_names设置选项。在windows平台可以在my-default.ini文件中设置,该文件位于 c:/program files/mysql/mysql server x.y 目录下。在linux平台可以修改my.cnf中的设置项。
缺省的选项--
linux平台:大小写敏感 case-sensitive
windows平台:大小写不敏感 case-insenstitive
问题的原因找到啦,我们可以在linux中设置lower_case_table_names为1启用大小写不敏感。也可以设置mysql在windows中大小写敏感,但是这不是个好主意。
记住,更改设置后需要重启mysql服务。
在linux中最好使用大小写敏感的设置,会获得更高的性能。在windows平台最好使用大小写不敏感的设置,因为不能存在两个仅有大小写差异而文件名字母相同的表。
由此而生,这也是为什么linux下mysql的性能会好过windows下的原因。(其他原因有:更好的计划调度更快的磁盘io和文件系统)
也可以在创建数据库时使用下面的语句来指定大小写敏感设置:
create database test_database character set utf8 collate utf8_general_cs; //实测:这一句不能在windows平台下的mysql使用;create database test_database character set utf8 collate utf8_general_ci;
相应的,也可以为某一个数据表设置大小写敏感:
drop table if exists single_test_table;create table single_test_table( single_test_id int unsigned not null auto_increment, ... primary key pk_single_test_id (single_test_id ), ...) engine=myisam default charset=utf8 collate utf8_general_cs;
官方文档5.6.10中指出:
if you are using innodb tables, you should set this variable to 1 on all platforms to force names to be converted to lowercase.
如果使用innodb引擎,应该在所有的平台设置lower_case_table_names=1强制名称都转换为小写。
如果要使windows平台下的mysql和linux平台下的mysql协同工作,你需要设置linux平台下的全局变量lower_case_table_names=1,强制将数据表名称转换为小写(大小写不敏感)。
bitscn.com