MySQL关于表名的大小写问题

MySQL关于表名的大小写问题
 
来源: ChinaUnix博客  日期: 2007.12.12 19:44 (共有条评论) 我要评论
 
在linux环境下,表的名称是区分大小写的,而在winodws环境下,表名则不区分大小写。因而如果设置不当,windows下的应用程序连接linux下的MySQL数据库常常提示table xxx doesn't exits的情况。
    
        
    
        
            
一、MySQL中关于大小写有两个变量:
                        · 
                        
                        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
                
                
                

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u1/42825/showart_441144.html
posted @ 2013-05-23 09:51  ygr158930  阅读(208)  评论(0编辑  收藏  举报