分类: LINUX
2007-12-12 19:44:20
在linux环境下,表的名称是区分大小写的,而在winodws环境下,表名则不区分大小写。因而如果设置不当,windows下的应用程序连接linux下的MySQL数据库常常提示table xxx doesn't exits的情况。
· lower_case_file_system
该变量说明是否数据目录所在的文件系统对文件名的大小写敏感。ON说明对文件名的大小写不敏感,OFF表示敏感。
· lower_case_table_names
如果设置为1,表名用小写保存到硬盘上,并且表名比较时不对大小写敏感。如果设置为2,按照指定的保存表名,但按照小写来比较。该选项还适合数据库名和表的别名。
如果你正使用InnoDB表,你应在所有平台上将该变量设置为1,强制将名字转换为小写。
如果运行MySQL的系统对文件名的大小写不敏感(例如Windows或Mac OS X),你不应将该变量设置为0。如果启动时没有设置该变量,并且数据目录所在文件系统对文件名的大小写不敏感,MySQL自动将lower_case_table_names设置为2。
二、为了消除linux环境下大小写敏感问题,笔者的设置如下:
1.修改my.cnf配置文件
shell>vi /etc/my.cnf
[mysqld]
lower_case_table_names=1